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INTERNATIONAL APPLICATION NO. 
PCT/JP99/00860 



INTERNATIONAL FILING DATE 
2 September 1999 (2.9.99) 



PRIORITY DATE CLAIMED 
27 February 1998. (27.2.98) 



APPLICANTfS^ FOR DO/EO/US 

Kenji HIRANO, Shinji KITAMURA and Tatsuhiko MURATO 



Applicant herewith submits to the United States Designated/Elected Office (DO/EO/US) the following items and other information: 

1. S This is a FIRST submission of items concerning a filing under 35 U.S.C. 371. 

2. EH This is a SECOND or SUBSEQUENT submission of items concerning a filing under 35 U.S.C. 371. 

3. [J] This express request to begin national examination procedures (35 U.S.C. 371(f)) at any time rather than delay 

~~ examination until the expiration of the applicable time limit set in 35 U.S.C. 371(b) and PCT Articles 22 and 39(1). 

4. EJ A proper Demand for International Preliminary Examination was made by the 19th month from the earliest claimed priority date. 

5. [x3 A copy of the International Application as filed (35 U.S.C. 371(c)(2)) 

a. ~fCl isjransmitted herewith (required only if not transmitted by the International Bureau). 

b. LH n^Mjeen transmitted by the International Bureau. 

c. ED is not required, as the application was filed in the United States Receiving Office (RO/US). 

6. [x] A translation of the International Application into English (35 U.S.C. 371(c)(2)). 

7. ED Amendments to the claims of the International Application under PCT Article 19 (35 U.S.C. 371(c)(3)) 

a ED are transmitted herewith (required only if not transmitted by the Internationa! Bureau). 

b. □ have been transmitted by the International Bureau. 

c. EU have not been made; however, the time limit for making such amendments has NOT expired. 

d. [x] have not been made and will not be made. 

8. EH A translation of the amendment^ to the claims under PCT Article 19 (35 U.S.C. 371(c)(3)). 

9. EH An oath or declaration of the inleH.tor(s) (35 U.S.C. 371(c)(4)). 

!0. EH A translation of the annexes to the International Preliminary Examination Report under PCT Article 36 
X35 U.S.C. 371(c)(5)). 

Items 11. to 16. below concern document(s) or information included: 

11. [H An Information Disclosure Statement under 37 CFR 1.97 and 1.98. 

12. EH An assignment document for recording. A separate cover sheet in compliance with 37 CFR 3.28 and 3.31 is included. 

13. Q A FIRST preliminary amendment. 

EH A SECOND or SUBSEQUENT preliminary amendment. 

14. EH A substitute specification. 

15. EH A change of power of attorney and/or address letter. 

16. [xj Other items or information: 

Copy of Form PCT/RO/101, PCT Request, Japanese Language, and PCT application as filed; 
Copy of International Preliminary Examination Report (PCT/IPEA/409 ) ; 
Copy of International Search Report (PCT/ISA/210 ) 

Copy of first page of published International Application No. W099/44368 

Verified Certification of Express Mailing Data (International Application) 37 C.P.R. 

1.10; and 

Return receipt postcard. 



BSdRec'dPCTPTfl IfiAlin ?flflff 



U.S.APPUCATIONNO (ifloiowi 



O (if known, see 37 CFR ! 5) ~J 

; following fees are suBifiitfe( 



J INTERNATIONAL APPUCATION NO 

■ PCT/JP99/00860 
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17. The following fees are sufiifiit^d: 
BASIC NATIONAL FEE ( 37 CFR 1.492 (a) (1) - (5) ) : 

Neither international preliminary examination fee (37 CFR 1 .482) 
nor international search fee (37 CFR 1.445(a)(2)) paid to USPTO 

and International Search Report not prepared by the EPO or JPO $970.00 

International preliminary examination fee (37 CFR 1.482) not paid to 

USPTO but International Search Report prepared by the EPO or JPO $840.00 

International preliminary examination fee (37 CFR 1.482) not paid to USPTO but 

international search fee (37 CFR 1 .445(a)(2)) paid to USPTO S690.00 

International preliminary examination fee paid to USPTO (37 CFR 1.482) 

but all claims did not satisfy provisions of PCT Article 33(l)-(4) S670.00 

International preliminary examination fee paid to USPTO (37 CFR 1.482) 



and all claims satisfied provisions of PCT Article 33(l)-(4) $96.00 

ENTER APPROPRIATE BASIC FEE AMOUNT = 



CALCULATIONS pto USE ONLY 



$840.00 



Surcharge of $130.00 for furnishing the oath or declaration later than HH ^0 I I 30 
months from the earliest claimed priority date (37 CFR 1.492(e)). 



NUMBER FILED 



NUMBER EXTRA 



ilndependent claims 



$780.00 



MULTIPLE DEPENDENT CLAIM(S) (if applicable) 



TOTAL OF ABOVE CALCULATIONS 



Reduction of 1/2 for filing by small entity, if applicable. A Small Entity Statement 
must also by filed (Note 37 CFR 1.9, 1.27, 1.28). 



SUBTOTAL 



^1,620.00 



Processing fee of $130.00 for furnishing the English translation later than [I]20 [I] 30 
months from the earliest claimed priority date (37 CFR 1.492(f)). + 



TOTAL NATIONAL FEE 



Tee for recording the enclosed assignment (37 CFR 1.21(h)). The assignment must be 
accompanied by an'kppropriate cover sheet (37 CFR 3.28, 3.31). S40.00 per property 
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A duplicate copy of this sheet is enclosed. 

The Commissioner is hereby authorized to charge any additional fees which may be required, or credit any 

overpayment to Deposit Account No A duplicate copy of this sheet is enclosed. 

Order No. 3620-4010 



NOTE: Where an appropriate time limit under 37 CFR 1.494 or 1.495 has not been met, 
1.137(a) or (b)) must be filed and granted to restore the application to pending status. 
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PATENT 
Docket No. 3620-4010 

IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

Applicants : Kenji Hirano et al. 

Serial No : To be Assigned 

Filed : August 15, 2000 (Herewith) 

For : IMAGE DATA PROCESSOR AND PROCESSING METHOD 

Group Art Unit: To be Assigned 

Examiner : To be Assigned 

Assistant Commissioner for Patents 
Box PCX 

Washington, D.C. 20231 
Attention: DO/EO/US 

PRELIMINARY AMENDMENT 

Sir: 

Prior to examination, please amend the above-identified application as 

follows: 

IN THE CLAIMS : 

Please delete claims 3, 4, 7 and 8. 

Please amend the claims 1, 5 and 6 as follows. 

1 . (Amended) A data processor for processing a block formed by two- 
dimensional data in a plurality of rows and a plurality of columns, characterized in that it 
comprises: 

storage means for storing the data of the block; 

write means for writing the data of the block in said storage means in a first 
order of scan which is either of the order of raster scan and the order of zigzag scan and 

563433 1 



read means for reading the data of the block stored in said storage means in a 
second order of scan which is the other of the order of raster scan and the order of zigzag 
scan and in that: 

said storage means includes n memories where n is an integer equal to or 
greater than 2, and the data of the block are distributed to said n memories such that n items 
of data consecutive in the first order of scan are stored in n different memories and n items of 
data consecutive in the second order of scan are stored in the different n memories; 
said write means simultaneously writes data in the different memories in the first order of 
scan; and 

said read means simultaneously reads the data from the different memories in 
the second order of scan. 

5. (Amended) A method for processing data for processing a block formed by 
two-dimensional data in a plurality of rows and a plurality of columns, characterized in that 
it comprises the steps of: 

distributing the data of the block to n memories and storing them in the 
different memories by simultaneously writing the same in a first order of scan such that n 
items of data (n is an integer equal to or greater than 2) consecutive in the first order of scan 
which is either of the order of raster scan and the order of zigzag scan are stored in the n 
different memories and such that n items of data consecutive in a second order of sca n which 
is the other of the raster scan and the order of zigzag scan are stored in the n different 
memories; and 

reading the stored data of a block from the different memories in the second 

order of scan. 
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6. (Amended) A method for processing data for processing a block formed by 
two-dimensional data in m rows and m columns, characterized in that it comprises the steps 
of: 

distributing the data of the block to n memories and storing them in the 
different memories by simultaneously writing the same in a first order of scan such that n 
items of data (n is an integer equal to or greater than 2, and n is a divisor of m which is equal 
to or greater than 2) consecutive in the first order of scan which is either of the order of 
raster scan and the order of the zigzag scan are stored in the n different memories and such 
that n items of data consecutive in a second order of scan which is the order of the raster 
scan and the order of zigzag scan are stored in the n different memories; and 

reading the stored data of a block from the different memories in the second 

order of scan. 

REMARKS 

The foregoing amendments to the claims are made to correct improper 
multiple dependency as it was presented in the attachment to the International Preliminary 
Examination Report. These amendments do not affect the scope of the invention claimed 
and is supported by the originally filed claims and the specification. 

No new matter has been added, and entry is respectfully requested. 



Dated:. 




MORGAN & FINNEGAN, L.L.P 

345 Park Avenue 

New York, New York 10154 

(212) 758-4800 

(212) 751-6849 
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DESCRIPTION 

IMAGE DATA PROCESSOR AND PROCESSING METHOD 

TECHNICAL FIELD 

The present InventlS'rf "folates to a technique for 
processing mage data and to a technique for performing an image 
compression process and a decompression process at a higher 
speed. 

BACKGROUND OF THE INVENTION 

Image data includes a huge amount of information. It 
is therefore impractical to process image data as it is from 
the viewpoint of the memory capacity and communication speed. 
Techniques for compressing image data are therefore important. 

One of international standards for image data 
compression is the JPEG (Joint Photographic Expert Group). 
JPEG adopts the DCT (discrete cosine transformation) method 
which involves irreversible encoding and the reversible 
encoding method which involves DPCM (differential PCM) in a 
two-dimensional space. The compression of image data 
according to the DCT method will now be described. 

Fig. 18 is a block diagram showing a basic configuration 
of a system for performing image data compression and image 
data decompression according to the DCT method. 

At the encoding end, a DCT process portion 100 performs 
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a discrete cosine transformation (hereinafter referred to as 
"DCT") process on original image data input thereto to output 
DCT coefficients. A quantizing portion 200 quantizes the DCT 
coefficients output by the DCT process portion 100 with 
reference to a quantization table 400 to output quantized DCT 
coefficients. Image quality and the amount of encoded 
information are controlled through such quantization. A 
Huffman encoding portion 206 performs a Huffman encoding 
process on the DCT coefficients output by the quantizing 
portion 200 to output compressed image data. 

At the decoding end, a Huffman decoding portion 211 
performs a Huffman decoding process on compressed image data 
with reference to an encoding table 500 to output quantized 
DCT coefficients. A dequantizing portion 700 performs 
dequantization on the quantized DCT coefficients with 
reference to the quantization table 400 to output DCT 
coefficients . A reverse DCT process portion 800 performs a 
reverse DCT process on the DCT coefficients to output 
reproduced image data. 

Next^ the DCT process performed by the DCT process 
portion 100 will be described. First, as shown in Fig. 19, 
image data is divided into a plurality of 8 X 8 pixel blocks . 
As shown in Fig. 20, one 8X8 pixel block includes 64 items 
of pixel data Pxy (X, Y = 0, 7). Two-dimensional DCT 

expressed by Equation 1 is performed on each of 8 X 8 pixel 
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blocks thus divided. 
(Equation 1) 



where Sw {U, V = 0, 7) represents DCT coefficients. When 
the bit precision of pixel data Pxy is 8 bits, Ls = 128 and, 
when the bit precision of pixel data Pxy is 12 bits, Ls = 2048. 

As a result of the DCT process. 64 DCT coefficients Suv 
are obtained. The DCT coefficient Soo is referred to as "DC 
coefficient", and the remaining 63 DCT coefficients are 
referred to as "AC coefficients". As shown in Fig. 20, the 
number of horizontal frequency components at high frequencies 
included in a block which has been subjected to the DCT process 
increases from left to right, and the number of vertical 
frequency components at high frequencies included increased 
from top to bottom. 

At the reverse DCT process portion 800, 64 pixel data 
Pxy {X, Y = 0, 7) are obtained from the DCT coefficients Suv 
through a reverse DCT process expressed by Equation 2. 
(Equation 2) 



As shown in Fig. 21, two-dimensional DCT is performed 
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by two one -dimensional DCT circuits 110 and 130 and an inversion 
memory 120. The horizontal direction of an 8 X 8 pixel block 
is referred to "row direction", and the vertical direction is 
referred to as "column direction" . 

The one -dimensional DCT 110 performs one -dimensional 
DCT as expressed by Equation 3 on image data fx, and writes 
one- dimensional DCT coefficients Fu representing the results 
in each row of the inversion memory 120. 
(Equation 3) 



The one -dimensional DCT circuit 130 performs one- 
dimensional DCT on the one-dimensional DCT coefficients Fu 
stored in each row of the inversion memory 120 and outputs the 
results as DCT coefficients Sw 

One -dimensional reverse DCT is expressed by Equation 4. 
(Equation 4) 



A description will now be made on the Huffman encoding 
process performed by the Huffman encoding portion 206. Fig. 
22 shows examples of DCT coefficients output by the quantizing 
portion 200. In Fig. 22, "A", "B", "C", "D", "E" and "F" 
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represent values other than "0". 

The Huffman encoding portion 206 in Fig. 18 performs a 
Huffman encoding process on DCT coefficients output by the 
quantizing portion 200 to output compressed image data. 
Referring to encoding of a DC coefficient, the difference 
between the DC coefficient of the current block and the DC 
coefficient of the preceding block is obtained, and a Huffman 
code is assigned to the difference. 

Referring to encoding of AC coefficients, as shown in 
Fig. 23, the AC coefficients are first arranged on a one- 
dimensional basis as a result of zigzag scan. The one- 
dimensionally arranged AC coefficients are encoded using run 
lengths representing the length of consecutive coefficients 
"0" (invalid coefficients) and the values of coefficients 
(valid coefficients) other than "0". The valid coefficients 
are divided into groups , and a group number is assigned to each 
valid coefficient. When AC coefficients are encoded, a 
Huffman code is assigned to a combination of a run length and 
a group number. Original image data are encoded into compressed 
image data as described above. 
[First Object] 

As described above, a block consisting of 8 X 8 = 64 data 
is treated as one unit to be processed according to the JPEG 
method. At the DCT process, two-dimensional DCT is performed 
by performing one -dimensional DCT in the column direction and 
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one -dimensional DCT in the row direction on data in each block. 
Similarly, at the reverse DCT process, two-dimensional reverse 
DCT is performed by performing one-dimensional reverse DCT in 
the column direction and one -dimensional reverse DCT in the 
row direction on data in each block. An inversion memory for 
storing 64 items of data in one block is used in such a DCT 
process and reverse DCT process. 

In this case, as shown in Fig. 24(a), data are written 
in an inversion memory TM in the order of raster scan in the 
row direction and, as shown in Fig. 24(b) , the data stored in 
the inversion memory TM are read in the order of raster scan 
in the column direction. As a result, data in each block can 
be rearranged from the order of raster scan in the row direction 
to the order of raster scan in the column direction. 

In the Huffman encoding process and Huffman decoding 
process, a bank memory for storing 64 items of data of one block 
is used. At the encoding end, as shown in Fig. 25(a), data 
are written in a bank memory BM in the order of raster scan 
and, as shown in Fig. 25(b) , the data stored in the bank memory 
BM are read in the order of zigzag scan. As a result, data 
in each block can be rearranged from the order of raster scan 
to the order of zigzag scan. At the decoding end, as shown 
in Fig. 25(b) , data are written in a bank memory BM in the order 
of zigzag scan and, as shown in Fig. 25(a), the data stored 
in the bank memory BM are read in the order of raster scan. 
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As a result , data in each block can be rearranged from the order 
of zigzag scan to the order of raster scan. 

In order to increase the speed of a process, a plurality 
of items of data must be processed simultaneously. For example, 
at the DCT process and reverse DCT process, two inversion 
memories each having a storage capacity of 64 are used; and 
the same 64 items of data are stored in each of the two inversion 
memories; and different data are read from the two inversion 
memories simultaneously. This makes it possible to increase 
the data processing speed. Similarly, at the Huffman encoding 
process and Huffman decoding process, two bank memories each 
having a storage capacity of 64 are used; and the same 64 items 
of data are stored in each of the two bank memories; and 
different data are read from the two bank memories 
simultaneously. This makes it possible to increase the data 
processing speed. 

However, two inversion memories are required for each 
of the DCT process and reverse DCT process, and two bank 
memories are required for each of the Huffman encoding process 
and Huffman decoding process. This hinders efforts toward 
reductions of the size and cost of a system. 

It is therefore a first object to provide a data 
processor which is capable of rearranging data at a first speed 
and whose size and cost can be reduced. 
[Second Object] 
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A block consisting of 8 X 8 = 64 data is treated as one 
unit to be processed according to the JPEG method . For example , 
at the encoding end, as shown in Fig. 26, quantized DCT 
coefficients output by the quantizing portion 200 (see Fig. 
18) are stored in a bank memory 221 as data. As shown in Fig. 
27 , the data stored in the bank memory 221 are read in the order 
of zigzag scan in synchronism with a clock signal CLK and are 
sequentially transferred to a Huffman encoding circuit 222 
through 11 -bit data bus DBG. 

In the example in Fig. 27 , eight items of data "DO" , "Dl" , 
"0", "D2", "0", "0", "D3" and "D4" are sequentially transferred. 
Here, "0" represents an invalid coefficient, and "DO", "Dl", 
"D2", "D3" and "04" represent valid coefficients. 

When AC coefficients are encoded, the Huffman encoding 
circuit 222 detects run lengths Indicating the number of 
consecutive "Os" and valid coefficients based on the data 
sequentially transferred by the bank memory 221 and performs 
Huffman encoding based on combinations of a run length and a 
valid coefficient. 

In the conventional Huffman encoding portion 206, items 
of data are transferred from the bank memory 221 to the Huffman 
encoding circuit 222 one by one as described above and, 
therefore, the number of cycles required for processing the 
data can not be reduced. In the above -described example, the 
time required for processing eight items of data corresponds 
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to eight cycles of the clock signal CLK. Therefore, the speed 
of the process at the Huffman encoding portion 206 can not be 
increased. Similarly, the speed of the process at the Huffman 
decoding portion 211 can not be increased. 

It is therefore a second object to provide a Huffman 
encoder with an improved processing speed. It is another 
object to provide a Huffman decoder with an improved processing 
speed. 

[Third Object] 

Fig. 28 is a block diagram showing an example of a 
conventional Huffman decoder. A head search process portion 
311 detects the position of the head of a Huffman code from 
compressed image data and supplies compressed image data in 
a bit quantity corresponding to a maximum code length of Huffman 
codes counted from the detected head position to an address 
input terminal AD of a memory 312 as an address signal. 

The memory 312 has a storage capacity of 2^^ words . Here, 
k represents the maximum code length of Huffman codes. In 
each address in the memory 312, decoded data associated with 
a Huffman code represented by the address are stored. Each 
decoded data consists of a run length and a group number as 
described above. 

For example, if it is assumed that the maximum length 
k of Huffman codes is 16, decoded data corresponding to a 16 -bit 
long Huffman code "1111111111110101" are stored in an address 
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"1111111111110101". Decoded data corresponding to a 15-bit 
long Huffman code "111111111000010" are stored in two addresses 
"lllllllllOOOOlOX" . Here, X represents 0 and 1. Decoded data 
corresponding to a 2 -bit long Huffman code "01" are stored in 
2^^^ addresses "OIXXXXXXXXXXXXXX" . 

Since 16 -bit compressed image data corresponding to the 
maximum code length are thus supplied to the memory 312 as 
address signals, decoded data associated with a Huffman code 
shorter than the maximum code length must be stored in a 
plurality of addresses. 

For example, when compressed image data include a 2- 
bit Huffman code "01", 16-bit compressed image data "01..." are 
supplied to the memory 312 as an address signal. As a result, 
decoded data stored in an address "01..." are read and output 
from a data output terminal DO. Thus, the Huffman code 
included in the compressed image data is decoded. 

As described above, since compressed image data in a bit 
quantity corresponding to the maximum code length k of Huffman 
codes are supplied to the memory 312 as an address signal in 
the conventional Huffman decoder, the memory 312 must have a 
storage capacity of 2^ words . 

In this case, decoded data associated with a Huffman code 
shorter than the maximum code length k are stored in a plurality 
of addresses. That is, extra decoded data must be stored in 
addresses in a quantity much greater than the number of Huffman 
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codes . If it is assumed that the number of Huffman codes is 
represented by N. the utilization rate of the memory 312 is 
as very low as 

As a result, the circuit of the Huffman decoder becomes 
large-scale, and it becomes difficult to increase the 
processing speed. 

It is therefore a third object to provide a Huffman 
decoder with a reduced size and an increased speed. 
DISCLOSURE OF THE INVENTION 
[First Invention] 

A first invention (1-1) of the present invention is a 
data processor for processing a block formed by two-dimensional 
data in a plurality of rows and a plurality of columns , 
characterized in that it comprises: 

storage means for storing the data of the block; 

write means for writing the data of the block in said 
storage means in a first order of scan; and 

read means for reading the data of the block stored in 
said storage means in a second order of scan and in that : 

said storage means includes n memories where n is an 
integer equal to or greater than 2 , and the data of the block 
are distributed to said n memories such that n items of data 
consecutive in the first order of scan are stored in n different 
memories and n items of data consecutive in the second order 
of scan are stored in the different n memories; 
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said write means simultaneously writes data in different 
memories in the first order of scan; and 

said read means simultaneously reads the data from the 
different memories in the second order of scan. 

A first invention (1-2) of the present invention is a 
method for processing data for processing a block formed by 
two-dimensional data in a plurality of rows and a plurality 
of columns, characterized in that it comprises the steps of: 

distributing the data of the block to n memories and 
storing them in the different memories by simultaneously 
writing the same in a first order of scan such that n items 
of data (n is an integer equal to or greater than 2) consecutive 
in the first order of scan are stored in the different n memories 
and such that n items of data consecutive in a second order 
of scan are stored in the n different memories; and 

reading the stored data of the block from the different 
memories in the second order of scan simultaneously. 

In this case, data in the plurality of rows and the 
plurality of columns of the block are distributed to and stored 
in the n memories . The data of the block are distributed to 
the n memories such that n items of data consecutive in the 
first order of scan are stored in the different n memories and 
such that n items of data consecutive in the second order of 
scan are stored in the n different memories . It is therefore 
possible to simultaneously write data in the different memories 
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in the first order of scan with write means and to read the 
data simultaneously from the different memories in the second 
order of scan with read means . As a result , the data of the 
block can be rearranged from the first order of scan to the 
second order of scan at a high speed. In this case, the storage 
capacity required for each of the memories is 1/n of the number 
of items of data in one block. Therefore, there is provided 
a data processor and a method for processing data in which data 
can be processed at a high speed and which allows a smaller 
size and a low cost . 

A first invention (2-1) of the present invention is a 
data processor for processing a block formed by two-dimensional 
data in m rows and n columns , characterized in that it 
comprises : 

storage means for storing the data of the block; 

write means for writing the data of the block in said 
storage means in a first order of scan; and 

read means for reading the data of the block stored in 
said storage means in a second order of scan and in that : 

said storage means includes n memories where said n is 
a divisor of m, which is equal to or greater than 2, and the 
data of the block are distributed to said n memories such that 
n items of data consecutive in the first order of scan are stored 
in the n different memories and n items of data consecutive 
in the second order of scan are stored in the n different 
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memories ; 

said write means simultaneously writes data in the n 
different memories in the first order of scan; and 

said read means simultaneously reads the data from the 
n different memories in the second order of scan. 

A first invention (2-2) of the present invention is a 
method for processing data for processing a block formed by 
two-dimensional data in m rows and m columns, characterized 
in that it comprises the steps of: 

distributing the data of the block to n memories and 
storing them in the different memories by simultaneously 
writing the same in a first order of scan such that n items 
of data (n is an integer equal to or greater than 2, and n is 
a divisor of m, which is equal to or greater than 2) consecutive 
in the first order of scan are stored in the n different memories 
and such that n items of data consecutive in a second order 
of scan are stored in the n different memories; and 

reading the stored data of the block from the different 
memories in the second order of scan simultaneously. 

In this case, data in the m rows and m columns in the 
block are distributed to and stored in the n memories . The 
data of the block are distributed to the n memories such that 
n items of data consecutive in the first order of scan are stored 
in the n different memories and such that n items of data 
consecutive in the second order of scan are stored in the n 
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different memories . It Is therefore possible to 

simultaneously write data In the different memories in the 
first order of scan with write means and to read the data 
simultaneously from the different memories in the second order 
of scan with read means. As a result, the data of the block 
can be rearranged from the first order of scan to the second 
order of scan at a high speed. In this case, the storage 
capacity required for each of the memories is l/n of the number 
of items of data in one block. Therefore, there is provided 
a data processor and a method for processing data in which data 
can be processed at a high speed and which allow a small size 
and a low cost. 

A first invention (3-1) of the present invention is a 
data processor according to the first (1-1) of the present 
invention or the first (2-1) of the present invention, 
characterized in that said first order of scan is the order 
of raster scan in either of the column direction and the row 
direction and in that said second order of scan is the order 
of raster scan in the other of the column direction and the 
row direction. 

A first invention (3-2) of the present invention is a 
method for processing data according to the first (1-2) of the 
present invention or the first (2-2) of the present invention, 
characterized in that said first order of scan is the order 
of raster scan in either of the column direction and the row 
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direction and in that said second order of scan is the order 
of raster scan in the other of the column direction and the 
row direction. 

In this case, the data of a block can be rearranged from 
the order of raster scan in the row direction or in the column 
direction to the order of raster scan in the column direction 
or in the row direction at a high speed. 

A first invention (4-1) of the present invention is a 
data processor according to the first (1-1) of the present 
invention or the first (2-1) of the present invention, 
characterized in that said first order of scan is either of 
the order of raster scan and the order of zigzag scan and in 
that said second order of scan is the other of the order of 
raster scan and the order of zigzag scan. 

A first invention (4-2) of the present invention is a 
method for processing data according to the first (1-2) of the 
present invention or the first (2-2) of the present invention, 
characterized in that said first order of scan is either of 
the order of raster scan and the order of zigzag scan and in 
that said second order of scan is the other of the order of 
raster scan and the order of zigzag scan. 

In this case, the data of a block can be rearranged from 
the order of raster scan to the order of zigzag scan at a high 
speed. 

[Second Invention] 
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A second Invention (1-1) of the present invention is a 
Huffman encoder for encoding DCT coefficients into Huffman 
codes , characterized in that it comprises : 

storage means for storing a plurality of DCT 
coefficients ; 

read means for reading a plurality of the DCT 
coefficients stored in said storage means at a time; 

counting means for counting the number of consecutive 
invalid coefficients until a valid coefficient is encountered 
in the DCT coefficients read by said read means from said 
storage means and for sequentially outputting data constituted 
by combinations of the number of consecutive invalid 
coefficients and a valid coefficient; and 

encoding means for performing a Huffman encoding process 
based on the data sequentially output by said counting means 
to generate Huffman codes. 

A second invention (1-2) of the present invention is a 
method for Huffman encoding for encoding DCT coefficients into 
Huffman codes, characterized in that it comprises the steps 
of: 

reading a plurality of DCT coefficients at a time; 

counting the number of consecutive invalid coefficients 
until a valid coefficient is encountered among the read DCT 
coefficients and sequentially calculating data constituted by 
combinations of the number of consecutive invalid coefficients 
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and a valid coefficient; and 

performing a Huffman encoding process based on the 
sequentially calculated data to generate Huffman codes. 

In this case, a plurality of the DCT coefficients stored 
in the storage means are read by the read means at a time. The 
number of consecutive invalid coefficients is counted by the 
counting means until a valid coefficient is encountered among 
the DCT coefficients read from the storage means to 
sequentially output data constituted by combinations of the 
number of consecutive invalid coefficients and a valid 
coefficient. The encoding means performs a Huffman encoding 
process based on the data sequentially output by the counting 
means to generate Huffman codes. Thus, since a plurality of 
DCT coefficients are read from the storage means at a time, 
the number of cycles required for the transfer of the DCT 
coefficients from the storage means to the counting means is 
reduced. Further, the number of items of data output by the 
counting means is reduced when invalid coefficients 
consecutively exist in the DCT coefficients read from the 
storage means, which reduces the number of cycles required for 
the transfer of data from the counting means to the encoding 
means and reduces the processing load of the encoding means. 
This increases the processing speed of a Huffman encoder and 
a method for Huffman encoding, thereby providing improved 
performance . 
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A second invention (2-1) of the present invention is a 
Huffman encoder for encoding DCT coefficients into Huffman 
codes , characterized in that it comprises : 

storage means for storing a plurality of DCT 
coefficients ; 

read means for reading a plurality of the DCT 
coefficients stored in said storage means at a time; 

a plurality of data buses for respectively transferring 
a plurality of the DCT coefficients read by said read means 
from said storage means at a time; 

a plurality of data storage means for storing input data 
and outputting the same in the order of input; 

counting means for counting the number of consecutive 
invalid coefficients until a valid coefficient is encountered 
in the DCT coefficients transferred by said plurality of data 
buses and for sequentially inputting data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient to said plurality of data storage means ; 

selection means for sequentially selecting and 
outputting data respectively output by said plurality of data 
storage means ; and 

encoding means for performing a Huffman encoding process 
based on the data output by said selection means to generate 
Huffman codes. 

A second invention ( 2 - 2 ) is a method for Huffman encoding 
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for encoding DCT coefficients into Huffman codes, 
characterized in that it comprises the steps of: 

reading a plurality of DCT coefficients at a time; 

transferring the plurality of read DCT coefficients 
using a plurality of data buses respectively; 

storing the transferred data respectively; 

counting the number of consecutive invalid coefficients 
until a valid coefficient is encountered among the transferred 
DCT coefficients and sequentially calculating data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; and 

performing a Huffman encoding process based on the 
calculated data to generate Huffman codes . 

In this case, a plurality of the DCT coefficients stored 
in the storage means are read by the read means at a time and 
are transferred by the plurality of data buses. The number 
of consecutive invalid coefficients is counted by the counting 
means until a valid coefficient is encountered among the DCT 
coefficients transferred by the plurality of data buses, and 
data constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient are sequentially 
input to the plurality of data storage means . Data 
respectively output by the plurality of data storage means are 
sequentially selected and output by the selection means, and 
a Huffman encoding process is performed by the encoding means 
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based on the data output by the selection means to generate 
Huffman codes . Thus , since a plurality of the DCT coefficients 
read from the storage means in pluralities are transferred to 
the counting means at a time, the number of cycles required 
for the transfer of the DCT coefficients from the storage means 
to the counting means is reduced. Further, the number of items 
of data output by the selection means is reduced when invalid 
coefficients consecutively exist in the DCT coefficients read 
from the storage means, which reduces the number of cycles 
required for the transfer of data from the selection means to 
the encoding means and reduces the processing load of the 
encoding means. This increases the processing speed of a 
Huffman encoder and a method for Huffman encoding, thereby 
providing improved performance. 

A second invention (3-1) of the present invention is a 
Huffman decoder for decoding Huffman codes into DCT 
coefficients, characterized in that it comprises: 

decoding means for performing a Huffman decoding process 
on Huffman codes input thereto to sequentially output data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; 

generation means for generating DCT coefficients based 
on the data output by said decoding means and for outputting 
a plurality of the generated DCT coefficients at a time; 

storage means for storing a plurality of DCT 
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coefficients; and 

write means for writing a plurality of the DCT 
coefficients output by said generation means in said storage 
means at a time. 

A second invention (3-2) of the present invention is a 
method for Huffman decoding for decoding Huffman codes into 
DCT coefficients, characterized in that it comprises the steps 
of: 

performing a Huffman decoding process on Huffman codes 
input thereto; 

sequentially outputting data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient; 

generating DCT coefficients based on the output data; 

outputting a plurality of the generated DCT coefficients 
at a time; and 

writing a plurality of the output DCT coefficients at 
a time . 

In this case, a Huffman decoding process is performed 
by the decoding means on input Huffman codes; data constituted 
by combinations of the number of consecutive invalid 
coefficients and a valid coefficient are sequentially output; 
DCT coefficients are generated by the generation means based 
on the output data; and a plurality of the generated DCT 
coefficients are output at a time. A plurality of the DCT 
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coefficients output by the generation means are written in the 
storage means by the write means at a time. Thus, the number 
of data output by the decoding means is reduced when a great 
number of consecutive invalid coefficients exist, which 
reduces the number of cycles required for the transfer of data 
from the decoding means to the generation means and reduces 
the processing load of the decoding means. Further, since a 
plurality of DCT coefficients are output by the generation 
means at a time and a plurality of the output DCT coefficients 
are written in the storage means at a time, the number of cycles 
required for the transfer of the DCT coefficients from the 
generation means to the storage means is reduced. This 
increases the processing speed of a Huffman decoder and a method 
for Huffman decoding, thereby providing improved performance. 

A second invention (4-1) of the present invention is a 
Huffman decoder for decoding Huffman codes into DCT 
coefficients, characterized in that it comprises: 

decoding means for performing a Huffman decoding process 
on Huffman codes input thereto to sequentially output data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; 

a plurality of data storage means for storing data input 
thereto and for outputting the same in the order of input; 

selection means for selecting the data output by said 
decoding means and sequentially inputting the same to said 
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plurality of data storage means; 

generation means for generating DCT coefficients based 
on the data output by said plurality of data storage means and 
for outputting a plurality of the generated DCT coefficients 
at a time; 

a plurality of data buses for respectively transferring 
a plurality of the DCT coefficients output by said generation 
means at a time; 

storage means for storing a plurality of DCT 
coefficients; and 

write means for writing a plurality of the DCT 
coefficients transferred by said plurality of data buses in 
said storage means at a time. 

A second invention (4-2) of the present invention is a 
method for Huffman decoding for decoding Huffman codes into 
DCT coefficients, characterized in that it comprises the steps 
of: 

performing a Huffman decoding process on Huffman codes 
input thereto ; 

sequentially calculating data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient; 

selectively storing the calculated data; 

generating DCT coefficients based on the stored data; 

outputting a plurality of the generated DCT coefficients 
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at a time; 

transferring the plurality of output DCT coefficients 
using a plurality of data buses respectively; and 

writing a plurality of the transferred DCT coefficients 
at a time. 

In this case, a Huffman decoding process is performed 
by the decoding means on input Huffman codes, and data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient are sequentially 
output. The data output by the decoding means are selected 
by the selection means and are sequentially input to the 
plurality of storage means. DCT coefficients are generated 
by the generation means based on the data output by the 
plurality of data storage means, and a plurality of the 
generated DCT coefficients are output at a time and are 
respectively transferred by the plurality of data buses. A 
plurality of the DCT coefficients transferred by the plurality 
of data buses are written in the storage means by the write 
means at a time. Thus, the number of items of data output by 
the decoding means is reduced when a great number of consecutive 
invalid coefficients exist, which reduces the number of cycles 
required for the transfer of data from the decoding means to 
the selection means and reduces the processing load of the 
decoding means. Further, since a plurality of the DCT 
coefficients are output by the generation means at a time and 



25 



a plurality of the output DCT coefficients are transferred to 
the storage means at a time, the number of cycles required, for 
the transfer of the DCT coefficients from the generation means 
to the storage means is reduced. This increases the 

processing speed of a Huffman decoder and a method for Huffman 
decoding, thereby providing improved performance. 
[Third Invention] 

A third invention (1-1) of the present invention is a 
Huffman decoder for decoding Huffman codes input thereto to 
output decoded data, characterized in that it comprises: 

a plurality of first storage means for respectively 
storing a predetermined number of Huffman codes among a 
plurality of Huffman codes; 

a plurality of match detection means provided in 
association with said plurality of first storage means, each 
of which detects match between an input Huffman code and the 
Huffman codes stored in the first storage means associated 
therewith; 

second storage means for storing a predetermined number 
of decoded data associated with said predetermined number of 
Huffman codes respectively and for outputting any of said 
predetermined number of decoded data in response to a signal 
output by said plurality of match detection means; 

frequency-of -occurrence generating means for 
generating a frequency of occurrence based on a Huffman code 
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input thereto ; and 

third storage means for storing decoded data in an 
address indicated by the frequency of occurrence of at least 
the plurality of remaining Huffman codes among said plurality 
of Huffman codes, for receiving the frequency of occurrence 
generated by said frequency- of -occurrence generating means as 
an address signal and for outputting decoded data from an 
address specified by the address signal. 

A third invention (1-2) of the present invention is a 
method for Huffman decoding for decoding Huffman codes to 
output decoded data, characterized in that it comprises the 
steps of: 

storing a predetermined number of Huffman codes among 
a plurality of Huffman codes respectively; 

storing a predetermined number of decoded data 
associated with said predetermined number of Huffman codes 
respectively ; 

detecting match between an input Huffman code and said 
stored Huffman codes associated therewith; 

outputting any of said predetermined number of decoded 
data in response to said match detection signal and storing 
decoded data in an address indicated by the frequency of 
occurrence of at least the plurality of remaining Huffman codes 
among said plurality of Huffman codes; 

generating a frequency of occurrence based on the input 
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Huffman code? 

receiving said frequency of occurrence as an address 
signal; and 

outputting decoded data from an address specified by 
said address signal. 

In this case, a predetermined number of Huffman codes 
among a plurality of Huffman codes are stored in the plurality 
of first storage means respectively. A predetermined number 
of decoded data associated with said predetermined number of 
Huffman codes are stored in the second storage means . Further, 
decoded data associated with at least the plurality remaining 
Huffman codes among the plurality of Huffman codes are stored 
in the third storage means. Each item of the decoded data is 
stored in an address indicated by the frequency of occurrence 
of a Huffman code associated therewith. 

The plurality of match detection means detect match 
between an input Huffman code and Huffman codes stored in the 
plurality of first storage means respectively. If the match 
detection means detect match between the input Huffman code 
and any of the Huffman codes stored in the plurality of storage 
means, any of the predetermined number of decoded data stored 
in the second storage means is output in response to a signal 
output by the plurality of match detection means . In this case , 
the input Huffman code is decoded at a high speed as a result 
of the match detection by the match detection means and the 
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output of the decoded data from the second storage means. 

The frequency-of -occurrence generating means generates 
a frequency of occurrence based on a Huffman code input thereto . 
The frequency of occurrence generated by the frequency- of - 
occurrence generating means is supplied to the third storage 
means as an address signal. When no match occurs between the 
input Huffman code and the Huffman codes stored in the plurality 
of first storage means, decoded data is output by the third 
storage means based on the frequency of occurrence supplied 
by the frequency-of -occurrence generating means as an address 
signal. 

Thus, since a predetermined number of decoded data 
associated with a predetermined number of Huffman codes 
respectively are stored in the second storage means , when an 
input Huffman codes matches any of the predetermined number 
of Huffman codes , the decoded data associated therewith is read 
at a high speed from the second storage means. When the input 
Huffman code matches none of the predetermined number of 
Huffman codes , the frequency of occurrence of the input Huffman 
code is generated, and decoded data associated therewith is 
read from the third storage means based on the frequency of 
occurrence . 

Huffman codes and frequencies of occurrence are in 
one-to-one correspondence, and frequencies of occurrence and 
decoded data are also in one-to-one correspondence . Therefore , 
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the number of the decoded data stored in the third storage means 
is equal to the number of the plurality of Huffman codes at 
the maximum . 

Therefore, the third storage means is required to have 
only a small storage capacity. 

It is therefore possible to provide a Huffman decoder 
and a method for Huffman decoding which allow a small size and 
a higher processing speed. 

A third invention (2-1) of the present invention is a 
data processor according to the third (1-1) of the present 
invention, characterized in that said predetermined number of 
Huffman codes have frequencies of occurrence higher than those 
of the remaining Huffman codes . 

A third invention (2-2) of the present invention is a 
method for processing data according to the third (1-2) of the 
present invention, characterized in that said predetermined 
number of Huffman codes have frequencies of occurrence higher 
than those of the remaining Huffman codes . 

A third invention (3-1) of the present invention is a 
data processor according to the third (1-1) of the present 
invention, characterized in that said frequency -of -occurrence 
generating means includes : 

constant storing means for storing a constant set for 
each code length of Huffman codes; 

minimum code storing means for storing a minimum code 
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for each code Xength of the Huffman codes; 

code length detection means for detecting the code 
length of a Huffman code input thereto based on the minimum 
code for each code length stored in said minimum code storing 
means ; 

constant selection means for selecting any of the 
constants stored in said constant storing means based on the 
code length detected by said code length detection means ; and 

calculation means for calculating a frequency of 
occurrence based on the constant selected by said constant 
selection means and the input Huffman code. 

A third invention (3-2) of the present invention is a 
method for processing data according to the third (1-2) of the 
present Invention, characterized in that said step of 
generating a frequency of occurrence includes the steps of: 

storing a constant set for each code length of Huffman 

codes ; 

storing a minimum code for each code length of the 
Huffman codes; 

detecting the code length of an input Huffman code based 
on said stored minimum code for each code length; 

selecting any of the stored constants based on said 
detected code length; and 

generating a frequency of occurrence based on the 
selected constant and the input Huffman code. 
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In this case, the frequency of occurrence of a Huffman 
code is obtained by subtracting a constant set for each code 
length from the Huffman code. The constant storage means 
stores the constant set for each code length of Huffman codes. 
The minimum code storage means stores a minimum code for each 
code length of Huffman codes. The code length of an input 
Huffman code is detected based on the minimum code for each 
code length stored in the minimum code storage means , and any 
of the constants stored in the constant storage means is 
selected based on the detected code length. A frequency of 
occurrence is calculated based on the selected constant and 
the input Huffman code. 

A third invention (4-1) of the present invention is a 
data processor according to the third (1-1) of the present 
invention, characterized in that it further comprises decoded 
data selecting means for selectively outputting decoded data 
output by said second and third storage means . 

A third invention (4-2) of the present invention is a 
method for processing data according to the third (1-2) of the 
present invention, characterized in that the output decoded 
data are selectively output. 

When an input Huffman code matches the predetermined 
number of Huffman codes, the decoded data output by the second 
storage means is selectively output and, when the input Huffman 
code does not match the predetermined number of Huffman codes , 
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the decoded data output by the third storage means is 
selectively output. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram showing a configuration of a 
data processor in a first embodiment of the first invention. 
Fig. 2 illustrates a method for distributing data in odd- 
numbered blocks to memories according to said first embodiment . 
Fig. 3 illustrates a method for distributing data in even- 
numbered blocks to memories according to said first embodiment . 
Fig. 4 illustrates changes in the address and write data for 
the odd- numbered blocks in said first embodiment during a write . 
Fig. 5 illustrates changes in the address and read data for 
odd-numbered blocks in said first embodiment during a read. 
Fig. 6 illustrates a method for distributing data of a block 
among two inversion memories. Fig. 7 illustrates a method for 
distributing data of a block among four inversion memories. 
Fig. 8 illustrates a method for distributing data of a block 
among eight inversion memories. Fig. 9 illustrates a method 
for distributing data of a block to memories according to a 
second embodiment of the first invention. Fig. 10 illustrates 
changes in the address and data during a write and read in said 
second embodiment. Fig. 11 illustrates changes in the address 
and data during a write and read in said second embodiment. 
Fig. 12 illustrates a method for distributing data of a block 
among four bank memories . 
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Fig. 13 is a block diagram showing a configuration of 
a Huffman encoder In a first embodiment of the second invention. 
Fig. 14 illustrates an example of an operation of the Huffman 
encoder in Fig. 13. Fig. 15 is a block diagram showing a 
configuration of a Huffman decoder in a second embodiment of 
the second invention. 

Fig. 16 is a block diagram showing a configuration of 
a Huffman decoder in an embodiment of the third invention . Fig . 
17 is a block diagram showing a configuration of a 
frequency- of -occurrence generation portion included in the 
Huffman decoder in Fig. 16. 

Figs. 18 through 28 are illustrations of the prior art. 
In Figs. 1 though 12, 1 and 2 represent memories; 3 represents 
a control portion; 4 and 5 represent bit switching portions; 
6 represents a write address counter; 7 represents a read 
address counter; 8, 9, 10 and 11 represent address conversion 
portions; 12, 13, 14 and 15 represent address switching 
portions; and 16 represents a read data switching portion. 

In Figs. 13 through 15, 201 and 215 represent bank 
memories; 202 and 216 represent address generating portions; 
203 and 214 represent data counter portions; 204a, 204b, 213a 
and 213b represent FIFOs; 205 and 212 represent selectors; 206 
represents a Huffman encoding portion; and 211 represents a 
Huffman decoding portion. 

In Figs. 16 and 17, 301 represents a head search process 
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portion; 302 represents a frequency-of -occurrence generating 
portion: 303 represents a memory: 304 represents a register; 
305 represents a selector; Rl and Rl represent registers; CI 
andCi represent comparators; 321 represents a constant storing 
portion; 322 represents a minimum code storing portion; 323 
represents a code length detecting portion; 324 represents a 
selector; and 325 represents an adder. 
BEST MODES FOR CARRYING OUT THE INVENTION 

Modes for carrying out the invention will now be 
described in detail with reference to the drawings. 
Throughout the drawings, like reference numbers indicate like 
or corresponding parts. 

[First Invention] 

Fig. 1 is a block diagram showing a configuration of a 
data processor in a first embodiment of the first invention 
(hereinafter referred to as "first embodiment"). 

The data processor of the first embodiment is used for 
rearranging 8X8 blocks of data from the order of raster scan 
in a row direction to the order of raster scan in a column 
direction or from the order of raster scan in the column 
direction to the order of raster scan in the row direction 
during a DCT process or reverse DCT process. 

The data processor in Fig. 1 includes two memories 1 and 
2, a control portion 3, bit switching portions 4 and 5, a write 
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address counter 6, a read address counter 7, address conversion 
portions 8, 9, 10 and 11, address switching portions 12, 13, 
14 and 15 and a read data switching portion 16. Each of the 
memories 1 and 2 has 32 addresses (a storage capacity of 32 
words) and is used as an inversion memory. 

Write data including two items of data are supplied to 
the bit switching portions 4 and 5 in the order of raster scan 
in the row direction or in the column direction. In this case, 
each item of written data includes the preceding item of data 
as a high order bit and the succeeding item of data as a low 
order bit . 

The bit switching portion 4 supplies the data of either 
the high order bit or low order bit of written data to a write 
data terminal WD of the memory 1 , and the bit switching portion 
5 supplies the data of the other of the high order bit and low 
order bit of the written data to a write data terminal WD of 
the memory 2 . 

The write address counter 6 counts clock signals CK 
supplied by the control portion 3 and generates write addresses 
for odd-numbered blocks. The address conversion portion 8 
converts the write addresses for odd-numbered blocks output 
by the write address counter 6 into write addresses for 
even-numbered blocks . In response to switching signals SW 
from the control portion 3, the address switching portion 12 
selectively supplies the write addresses output by write 



36 



address counter 6 or the write addresses output by the address 
conversion portion 8 to a write address terminal WA of the 
memory 1 . 

Similarly, the address conversion portion 10 converts 
write addresses for odd-numbered blocks output by the write 
address counter 6 into write addresses for even-numbered blocks 
In response to switching signals SW from the control portion 
3, the address switching portion 14 selectively supplies the 
write addresses output by write address counter 6 or the write 
addresses output by the address conversion portion 10 to a write 
address terminal WA of the memory 2 . 

The read address counter 7 counts clock signals CK 
supplied by the control portion 3 and generates read addresses 
for odd-numbered blocks. The address conversion portion 9 
converts the read addresses for odd-numbered blocks output by 
the read address counter 7 into read addresses for even- 
numbered blocks. In response to switching signals SR from the 
control portion 3, the address switching portion 13 selectively 
supplies the read addresses output by read address counter 7 
or the read addresses output by the address conversion portion 
9 to a read address terminal RA of the memory 1. 

Similarly, the address conversion portion 11 converts 
read addresses for odd-numbered blocks output by the read 
address counter 7 into read addresses for even-numbered blocks . 
In response to switching signals SR from the control portion 
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3, the address switching portion 15 selectively supplies the 
read addresses output by read address counter 7 or the read 
addresses output by the address conversion portion 11 to a read 
address terminal RA of the memory 2 . 

Write enable signals for permitting data writing are 
supplied by the control portion 3 to write enable terminals 
WEN of the memories 1 and 2 . As a result , data supplied to 
the write data terminal WD are written in storage locations 
specified by write addresses supplied to the write address 
terminal WA. 

Data are read from storage locations specified by read 
addresses supplied to the address terminals RA of the memories 
1 and 2 and are output from the read data terminals RD. In 
response to a control signal CN from the control portion 3, 
the read data switching portion 16 outputs read data which 
includes either of the two items of data output from the 
memories 1 and 2 preceding in the order of raster scan in the 
column direction or in the row direction as a high order bit 
and which includes the succeeding data as a low order bit . 

A method for processing data according to the first 
embodiment will now be described. The method for processing 
data of the first embodiment is used for rearranging 8X8 blocks 
of data from the order of raster scan in the row direction to 
the order of raster scan in the column direction or from the 
order of raster scan in the column direction to the order of 
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raster scan in the row direction during a DCT process or reverse 
DCT process. 

The method for processing data includes the step of 
distributing data of the blocks to two memories such that two 
items of data consecutive in the order of raster scan in the 
row direction are stored in the two different memories and such 
that two items of data consecutive in the order of raster scan 
in the colximn direction are stored in the two different memories , 
the step of writing the data in the two different memories in 
the order of raster scan in the row direction simultaneously, 
and the step of reading the stored data of the blocks from the 
different memories in the order of raster scan in the column 
direction simultaneously. 

The method for processing data will now be described in 
detail. 

First, a description will now be made with reference to 
Figs . 2 and 3 on a method for distribution at the step of 
distributing data of the block to the memories 1 and 2 in the 
method for processing data. In Figs. 2 and 3, the numerals 
"0" through "63" in the blocks are given to specify respective 
items of data. The horizontal direction of the blocks is the 
row direction, and the vertical direction thereof is the column 
direction. 

Data of odd-numbered blocks are written in the memories 
1 and 2 in the order of raster scan in the row direction, and 
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the data are read from the memories 1 and 2 in the order of 
raster scan in the coliamn direction. Data of even-numbered 
blocks are written in the memories 1 and 2 in the order of raster 
scan in the column direction, and the data are read from the 
memories 1 and 2 in the order of raster scan in the row direction. 
As a result, the next block can be written concurrently with 
the read of the current block. 

Referring to the odd-numbered blocks, as shown in Fig. 
2(a), 64 items of data are arranged in a 8 X 8 block in the 
row direction, and items of data in each row of the block are 
divided by twos in the row direction to generate sets of data 
each consisting of two items of data. Then, as shown in Fig. 
2(b), the two items of data of each set are distributed among 
different first and second groups. In Fig. 2, data belonging 
to the first group are hatched, and data belonging to the second 
group are not hatched. In this case, the two items of data 
of each set are distributed among the first and second groups 
such that two consecutive items of data belong to different 
groups when the data of the block are scanned in the column 
direction. 

Next, as shown in Fig. 2(c), the positions of the two 
items of data in each set in the odd-numbered rows are switched 
each other. As a result, data of the first group are located 
in the odd-numbered columns, and data of the second group are 
located in the even-numbered columns. As shown in Fig. 2(d), 



40 



the data of the first group in the odd- numbered columns are 
distributed to the memory 1, and the data of the second group 
in the even-numbered columns are distributed to the memory 2. 
In the figure, the addresses of the storage locations at the 
left ends of the memories 1 and 2 are "0" , "4", "8", "12", "16", 
"20", "24" and "28" in the descending order. 

By distributing data to the memories 1 and 2 in such a 
manner, two items of data consecutive in the order of raster 
scan in the row direction can be simultaneously written in the 
memories 1 and 2 respectively during a write, and two items 
of data consecutive in the order of raster scan in the column 
direction can be simultaneously read from the memories 1 and 
2 during a read. 

Referring to the even-numbered blocks, as shown in Fig. 
3(a), 64 items of data are arranged in a 8 X 8 block in the 
column direction, and items of data in each row of the block 
are divided by twos in the row direction to generate sets of 
data each consisting of two items of arrayed data. Then, as 
shown in Fig. 3(b), the two items of data in each set are 
distributed among different first and second groups. In Fig. 
3, data belonging to the first group are hatched, and data 
belonging to the second group are not hatched. In this case, 
the two items of data in each set are distributed among the 
first and second groups such that two consecutive items of data 
belong to different groups when the data of the block are 
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scanned in the column direction. 

Next, as shown in Fig. 3(c), the positions of the two 
items of data in each set in the odd-numbered rows are switched 
each other. As a result, data of the first group are located 
in the odd-numbered columns, and data of the second group are 
located in the even-numbered columns. As shown in Fig. 3(d), 
the data of the first group in the odd-numbered columns are 
distributed to the memory 1, and the data of the second group 
in the even-numbered columns are distributed to the memory 2. 
In the figure, the addresses of the storage locations at the 
left ends of the memories 1 and 2 are "0" , "4", "8", "12", "16", 
"20", "24" and "28" in the descending order. 

By distributing data to the memories 1 and 2 in such a 
manner, two items of data consecutive in the order of raster 
scan in the column direction can be simultaneously written in 
the memories 1 and 2 respectively during a write, and two items 
of data consecutive in the order of raster scan in the row 
direction can be simultaneously read from the memories 1 and 
2 during a read. 

Fig, 4 illustrates changes in the writing address and 
write data in the first embodiment- Fig. 4 shows a write of 
data in the odd-numbered blocks. 

As shown in Fig. 4, when the writing address supplied 
to the memories 1 and 2 changes, two consecutive items of data 
are simultaneously written in the memories 1 and 2 in the order 
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of raster scan ±n the row direction. 

Fig. 5 illustrates changes in the reading address and 
read data in the first embodiment. Fig. 5 shows a read of data 
from the odd- numbered blocks. 

As shown in Fig. 5, when the reading address supplied 
to the memories 1 and 2 changes, two consecutive items of data 
are simultaneously read from the memories 1 and 2 in the order 
of raster scan in the column direction. 

Thus , in the data processor and the method for processing 
data of the first embodiment, two items of data consecutive 
in the order of raster scan in the row direction or in the column 
direction are simultaneously written in the memories 1 and 2 
during a write, and two items of data consecutive in the order 
of raster scan in the column direction or in the row direction 
are simultaneously read from the memories 1 and 2 during a read, 
which makes it possible to increase the speed of data processing. 
Further, since 64 items of data can be simultaneously written 
and read in twos to and from the two memories 1 and 2 having 
32 addresses, the size and cost of a system can be reduced. 

While an example of distribution of data of a block among 
two inversion memories has been described in the first 
embodiment, the data of a block may be distributed among four 
or eight inversion memories . 

Fig. 6 illustrates a method for distributing data of 
blocks among two inversion memories; Fig. 7 illustrates a 
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method for distributing data of a block among four inversion 
memories; and Fig. 8 illustrates a method for distributing data 
of a block among eight inversion memories . In Figs .6,7 and 
8, data of a block are shown at (a); distribution of data in 
odd-numbered blocks is shown at (b) ; and distribution of data 
in even-numbered blocks are shown at (c). 

In odd-ntimbered blocks, data are arranged in the order 
of raster scan in the row direction and, in even-numbered blocks , 
data are arranged in the order of raster scan in the column 
direction . 

In the example in Fig. 6, data in each row are divided 
into four sets each including two items of data, and the two 
items of data in each set in the even-numbered rows are shifted 
one place in the set with the data in the odd- numbered rows 
unchanged. Then, data in the odd-numbered columns are 
distributed to an inversion memory BO, and data in the 
even-numbered columns are distributed to an inversion memory 
Bl. 

In the example in Fig. 7, data in each row are divided 
into two sets each including four items of data. The data in 
the first and fifth rows are kept unchanged; the four items 
of data in each set in the second and sixth rows are shifted 
one place in the set; the four items of data in each set in 
the third and seventh rows are shifted two places in the set; 
and the four items of data in each set in the fourth and eighth 



44 



rows are shifted three places In the set. Then, data In the 
first and fifth columns are distributed to an inversion memory 
BO; data In the second and sixth columns are distributed to 
an Inversion memory Bl; data in the third and seventh columns 
are distributed to an inversion memory B2; and data in the 
fourth and eighth columns are distributed to an inversion 
memory B3 . 

In the example in Fig. 8, data in each row are divided 
into one set each including eight items of data. The eight 
items of data in each set in the second through eighth rows 
are sequentially shifted by respective amounts , i.e., one place 
- seven places in the respective sets, with the data in the 
first row kept unchanged. Then, data in first through eighth 
columns are respectively distributed to inversion memories BO 
through B7. 

A description will now be made on a data processor and 
a method for processing data in a second embodiment of the first 
Invention (hereinafter referred to as "second embodiment"). 
The data processor and the method for processing data of the 
second embodiment are used to rearrange an 8 X 8 block of data 
from the order of raster scan to the order of zigzag scan or 
from the order of zigzag scan to the order of raster scan during 
a Huffman encoding process or Huffman decoding process. 

The data processor of the second embodiment has a 
configuration similar to the configuration of the data 
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processor shown in Fig. 1. The data processor of the second 
embodiment is different from the data processor of the first 
embodiment in the method for distributing data of a block to 
memories 1 and 2 and the method for specifying write addresses 
and read addresses . The memories 1 and 2 are used as bank 
memories . 

Next, a description will now be made with reference to 
Fig. 9 on a method for distributing data to the memories 1 and 
2 in the second embodiment. In Fig. 9, the numerals "0" through 
"63" in the block are given to specify respective items of data. 

The description refers to a case in which data are 
written in the memories 1 and 2 in the order of raster scan 
in the column direction and in which data are read from the 
memories 1 and 2 in the order of zigzag scan. 

As shown in Fig. 9(a), 64 items of data are arranged in 
a 8 X 8 block in the row direction. Then, items of data in 
each column of the block are divided by twos in the column 
direction to generate sets of data each consisting of two items 
of data. Then, as shown in Fig. 9(b), the two items of data 
in each set are distributed among different first and second 
groups. In Fig. 9, data belonging to the first group are 
hatched, and data belonging to the second group are not hatched. 
In this case, the two items of data in each set are distributed 
among the first and second groups such that two consecutive 
items of data belong to different groups when the data of the 
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block are scanned in the order of zigzag scan. 

Next, as shown in Fig. 9(c), the positions of the two 
data in each set in the odd- numbered columns are switched each 
other. As a result, data of the first group are located in 
the odd- numbered rows, and data of the second group are located 
in the even-numbered rows. As shown in Fig. 9(d), the data 
of the first group in the odd-numbered rows are distributed 
to the memory 1 , and the data of the second group in the 
even-numbered rows are written in the memory 2 . In the figure, 
the addresses of the storage locations at the left ends of the 
memories 1 and 2 are "0", "8", "16" and "24" in the descending 
order. 

By distributing data to the memories 1 and 2 in such a 
manner, two items of data consecutive in the order of raster 
scan in the column direction can be simultaneously written in 
the memories 1 and 2 respectively during a write, and two items 
of data consecutive in the order of zigzag scan can be 
simultaneously read from the memories 1 and 2 during a read. 

Figs . 10 and 11 illustrate changes in the writing address , 
write data, reading address and read data in the second 
embodiment . 

In the example in Figs. 10 and 11, data are written in 
and read from the memories 1 and 2 concurrently, and a read 
of data in one block is started when 32 items of data in the 
block have been written. 
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As shown in Figs. 10 and 11, when the writing address 
supplied to the memories 1 and 2 changes, two consecutive items 
of data are simultaneously written in the memories 1 and 2 in 
the order of raster scan in the column direction and, when the 
reading address supplied to the memories 1 and 2 changes, two 
consecutive items of data are simultaneously read from the 
memories 1 and 2 in the order of zigzag scan. 

Thus , in the data processor of the second embodiment , 
two items of data consecutive in the order of raster scan or 
in the order of zigzag scan are simultaneously written in the 
memories 1 and 2 during a write, and two items of data 
consecutive in the order of zigzag scan or in the order of raster 
scan are simultaneously read from the memories 1 and 2 during 
a read, which makes it possible to increase the speed of data 
processing. Further, since 64 items of data can be 
simultaneously written and read in twos to and from the two 
memories 1 and 2 having 32 addresses, the size and cost of a 
system can be reduced. 

Fig. 12 illustrates a method for distributing data of 
a block among four bank memories in which data of a block are 
shown at (a) and distribution of data is shown at (b) . 

In the example in Fig. 12 , four items of data consecutive 
in the order of raster scan or in the order of zigzag scan can 
be simultaneously written in bank memories BO, Bl, B2 and B3 
during a write, and four items of data consecutive in the order 
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of zigzag scan or in the order of raster scan can be 
simultaneously read from the bank memories BO, Bl, B2 and B3 
during a read. This makes it possible to reduce the size and 
cost of a system. 

[Second Invention] 

Fig. 13 is a block diagram showing a configuration of 
a Huffman encoder in a first embodiment of the second invention 
(hereinafter referred to as "third embodiment"). 

As shown in Fig. 13, the Huffman encoder includes a bank 
memory 201, an address generating portion 202, a data counter 
portion 203, FIFOs (first-in first-out memory) 204a and 204b, 
a selector 205 and a Huffman encoding portion 206- 

The bank memory 201 stores 8X8 quantized DCT 
coefficients output by a quantizing portion 200 (see Fig. 18) 
as data. The address generating portion 202 generates 
addresses for reading data from the bank memory 201 in the order 
of zigzag scan in synchronism with a clock signal CLK. Two 
items of data are stored in each address of the bank memory 
201. As a result, two items of data can be simultaneously read 
at one clock of the clock signal CLK. 

One of two items of data simultaneously read from the 
bank memory 201 is transferred to the data counter portion 203 
through an 11-bit data bus DBl, and the other is transferred 
to the data counter portion 203 through an 11-bit data bus DB2 . 
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The data counter portion 203 determines whether data 
supplied by the bank memory 201 is "0" (invalid coefficient) . 
If the data is "0", it counts the number of consecutive "Os" 
until a valid coefficient (a coefficient other than "0") is 
supplied and writes a run length representing the number of 
consecutive "Os" and a valid coefficient, as a set of data, 
in the FIFOs 204a and 204b alternately. When both of two items 
of data supplied by the bank memory 201 are not "0", the data 
counter portion 203 sets the run length of each item of data 
at "0" and writes the run length and a valid coefficient in 
each of the FIFOs 204a and 204b as a set of data. The data 
written in the FIFOs 204a and 204b are sequentially shifted 
and output . 

The selector 205 alternately selects data output by the 
FIFOs 204a and 204b and supplies them to the Huffman encoding 
portion 206 through a data bus DB3 . The Huffman encoding 
portion 206 performs a Huffman encoding process based on data 
constituted by combinations of a run length and a valid 
coefficient supplied by the selector 205 during encoding of 
AC coefficients to output compressed image data including 
Huffman codes . 

In the third embodiment, the bank memory 201 corresponds 
to the storage means; the address generating portion 202 
corresponds to the read means; the data counter portion 203 
corresponds to the counting means; and the Huffman encoding 
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portion 206 corresponds to the encoding means. The FIFOs 204a 
and 204b correspond to the data storage means, and the selector 
205 corresponds to the selection means. 

A method for encoding of the third embodiment will now 
be described. The method for encoding of the third embodiment 
is characterized in that it includes the step of reading a 
plurality of DCT coefficients at a time, the step of 
transferring the plurality of DCT coefficients using a 
plurality of data paths respectively, the step of storing the 
transferred data respectively, the step of counting the number 
of consecutive invalid coefficients among the transferred DCT 
coefficients until a valid coefficient is encountered and the 
step of calculating data constituted by combinations of the 
number of consecutive invalid coefficients and a valid 
coefficient sequentially and performing a Huffman encoding 

process based on the calculated data and in that it generates 

Huffman codes. 

The method for encoding will now be described in detail. 
Fig. 14 is an illustration of an example of the method 

for Huffman encoding in Fig. 13 in which a clock signal CLK 

and data on the data buses DBl and DB2 are shown at (a); the 

contents of the FIFOs 204a and 204b are shown at (b); and data 

on the data bus DB3 are shown at(c). 

It is assumed here eight items of data are processed. 

Data of DCT coefficients "DO", "Dl", "0", "D2", "0", "0", "D3" 
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and "D4" are read from the bank memory 201 as a result of zigzag 
scan. The data "DO", "Dl", "D2", "D3" and "D4" are valid 
coefficients, and "0" Is an invalid coefficient. 

As shown in Fig. 14(a), the data "DO" and "Dl" are 
simultaneously read; the data "0" and "D2" are simultaneously 
read; the data "0" and "0" are simultaneously read; and the 
data "D3" and "D4" are simultaneously read. The data "DO", 
"0", "0" and "D3" are transferred to the data counter portion 
203 through the data bus DBl, and the data "Dl". "D2", "0" and 
"D4" are transferred to the data counter portion 203 through 
the data bus DB2 . The time required for the transfer of the 
eight items of data from the bank memory 201 to the data counter 
portion 203 corresponds to four cycles of the clock signal CLK. 

Since the data "DO" supplied through the data bus DBl 
is a valid coefficient and the data "Dl" supplied through the 
data bus DB2 is also a valid coefficient, the data counter 
portion 203 writes a run length "0" and a valid coefficient 
"DO" in the FIFO 204a as a set of data and writes a run length 
"0" and a valid coefficient "Dl" in the FIFO 204b as a set of 
data. 

Next, since the data supplied through the data bus DBl 
is "0", the data counter portion 203 counts a run length "1" 
and, since the data "D2" supplied through the data bus DB2 is 
a valid coefficient, it writes a run length "1" and a valid 
coefficient "D2" in the FIFO 204a as a set of data. 
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Then, since the data supplied through the data bus DBl 
is "0", the data counter portion 203 counts a run length "1" 
and, since the data supplied through the data bus DB2 is "0", 
it counts a run length "2". Next, since the data "D3" supplied 
through the data bus DBl is a valid coefficient and the data 
"04" supplied through the data bus DB2 is a valid coefficient, 
the data counter portion 203 writes a run length "2" and a valid 
coefficient "D3" in the FIFO 204b as a set of data and a run 
length "0" and a valid coefficient "D4" in the FIFO 204a as 
a set of data. 

As a result, as shown in Fig. 14(b), "O/DO", "1/D2" and 
"0/04" are sequentially written in the FIFO 204a as run 
lengths/valid coefficients, and "0/Dl" and "2/D3" are 
sequentially written in the FIFO 204b as run lengths /valid 
coefficients . 

The selector 205 alternately selects data output from 
the FIFOs 204a and 204b and transfers them to the Huffman 
encoding portion 206 through the data bus DBS. As a result, 
as shown in Fig. 14(c), data "O/DO", "0/Dl", "1/D2", "2/D3" 
and " 0/D4 " representing combinations of a run length and a valid 
coefficient are sequentially supplied to the Huffman encoding 
portion 206. In this case, the time required for the transfer 
of the data from the selector 205 to the Huffman encoding 
portion 206 corresponds to five cycles of the clock signal CLK. 

Thus, the transfer of eight items of data from the bank 
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memory 201 to the data counter portion 203 is performed in four 
cycles, and the transfer of data from the selector 205 to the 
Huffman encoding portion 206 is performed in five cycles. 
Therefore, in the above example, eight items of data can be 
processed in five cycles. 

In the Huffman encoder and the method for encoding in 
the third embodiment, since tow items of data are 
simultaneously transferred from the bank memory 201 to the data 
counter portion 203, the number of cycles required for the 
transfer of data from the bank memory 201 to the data counter 
portion 203 is reduced. Further, the number of data output 
by the selector 205 is reduced when "Os" consecutively exit 
in data read from the bank memory 201, which reduces the number 
of cycles required for the transfer of data from the selector 
205 to the Huffman encoding portion 206 and the processing load 
of the Huffman encoding portion 206. In the third embodiment, 
the minimum number of cycles required for processing data is 
one half that in a conventional Huffman encoder. This makes 
it possible to increase the processing speed of a Huffman 
encoder and hence the performance of the same. 

While the third embodiment has referred to a case in 
which the width of the data bus from the bank memory 201 to 
the data counter portion 203 is as large as twice that in the 
prior art and in which two items of data are simultaneously 
read from the bank memory 201, a configuration may be employed 
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in which the width of the data bus from the bank memory 201 
to the data counter portion 203 is as large as Nb times that 
in the prior art and in which Nb items of data are simultaneously 
read from the bank memory 201. Here, Nb is any integer. In this 
case, the minimum number of cycles required for processing data 
is one-Nfith that in the conventional Huffman encoder and method 
for encoding. 

Fig. 15 is a block diagram showing a configuration of 
a Huffman decoder in a second embodiment of the second invention 
(hereinafter referred to as "fourth embodiment"). 

As shown in Fig» 15, the Huffman decoder includes a 
Huffman decoding portion 211 , a selector 212, FIFOs 213a and 
213b, a data counter portion 214, a bank memory 215 and an 
address generating portion 216. 

During decoding of AC coefficients , the Huffman decoding 
portion 211 performs a Huffman decoding process on Huffman 
codes included in compressed image data and transfers data 
constituted by combinations of a run length and a valid 
coefficient to the selector 212 through a data bus DB4 . The 
selector 212 alternately writes the data supplied by the 
Huffman decoding portion 211 in the FIFOs 213a and 213b. The 
data written in the FIFOs 213a and 213b are sequentially shifted 
and output . 

The data counter portion 214 generates a quantized DCT 
coefficient based on the run length and valid coefficient of 



55 



each item of data supplied by the FIFOs 213a and 213b and 
simultaneously outputs DCT coefficients thus generated in 
twos . 

One of two items of data simultaneously output by the 
data counter portion 214 is transferred to the bank memory 215 
through an 11-bit data bus DBS, and the other is transferred 
to the bank memory 215 through an 11-bit data bus DB6 . 

The address generating portion 216 generates addresses 
for writing data in the bank memory 215 in the order of zigzag 
scan in synchronism with a clock signal CLK. In this case, 
items of data are written in each address of the bank memory 
215 in twos. As a result, two items of data can be 
simultaneously written at one clock of the clock signal CLK. 
The bank memory 215 stores 8X8 quantized DCT coefficients 
supplied by the data counter portion 214 as data. The data 
stored in the bank memory 215 are supplied to a dequantization 
portion 700 (see Fig. 18). 

In the fourth embodiment, the Huffman decoding portion 
211 corresponds to the decoding means ; the data counter portion 
214 corresponds to the generation means; the bank memory 215 
corresponds to the storage means; and the address generating 
portion 216 corresponds to the write means. The selector 212 
corresponds to the selection means, and the FIFOs 213a and 213b 
correspond to the data storage means . 

In the Huffman decoder and method for decoding of the 
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fourth embodiment , the processing is carried out in a way which 
is the reverse of that in the Huffman encoding and method for 
encoding of the third embodiment . When run lengths have large 
values, the number of items of data output by the Huffman 
decoding portion 211 becomes small, which reduces the number 
of cycles required for the transfer of data from the Huffman 
decoding portion 211 to the selector 205 and the processing 
load of the Huffman decoding portion 211. Further, since two 
items of data are simultaneously transferred from the data 
counter portion 214 to the bank memory 215 , the number of cycles 
required for the transfer of data from the data counter portion 
214 to the bank memory 215 is reduced. In the fourth embodiment , 
the minimum number of cycles required for processing data is 
one half that in a conventional Huffman decoder and method for 
decoding. This increases the speed of a Huffman decoding 
process, thereby providing improved performance. 

While the fourth embodiment has referred to a case in 
which the width of the data bus from the data counter portion 
214 to the bank memory 215 is enlarged by a factor of two and 
in which two items of data are simultaneously written in the 
bank memory 215, a configuration may be employed in which the 
width of the data bus from the data counter portion 214 to the 
bank memory 215 is enlarged by a factor of Nb and in which Nb 
items of data are simultaneously written in bank memory 215. 
In this case, the minimum number of cycles required for 
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processing data is one-Neth that in the conventional Huffman 
decoder and method for decoding. 
[Third Invention] 

Fig. 16 is a block diagram showing a configuration of 
a Huffman decoder in an embodiment of the third invention 
(hereinafter referred to as "fifth embodiment"). 

The Huffman decoder in shown in Fig. 16 includes a head 
search process portion 301, a frequency- of -occurrence 
generating portion 302, a memory 303, i units of registers Rl 
through Ri, i units of comparators CI through Ci, a register 
304 and a selector 305. If it is assumed here that there are 
n Huffman codes, i satisfies a relationship of 0<i<N. In the 
fifth embodiment , i = 20 . In the fifth embodiment , the maximum 
code length k of Huffman codes is 16 bits. Normally, the 
shorter the code length of a Huffman code, the higher the 
frequency of occurrence of the same. For example, Huffman 
codes in the first through twentieth places in the frequency 
of occurrence have a code length of 8 bits or less. 

The head search process portion 301 detects the position 
of the head of each Huffman code from compressed image data 
input thereto, supplies 16 bits of compressed image data 
counted from the detected head position to the frequency- 
of -occurrence generating portion 302 and supplies 8 bits of 
compressed image data counted from the detected head position 
to the comparators CI through Ci. 
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The frequency-of -occurrence generating portion 302 
generates the frequencies of occurrence of Huffman codes 
included in the compressed image data supplied by the head 
search process portion 301 according to a method as described 
later and supplies the generated frequencies of occurrence to 
an address input terminal AD of the memory 303 as address 
signals . 

A RAM (random access memory) or the like is used as the 
memory 303. In each address of the memory 303, decoded data 
associated with a Huffman code having a frequency of occurrence 
indicated by the address is stored. Decoded data is 
constituted by a run length (the number of consecutive Os) and 
a group number. Huffman codes and frequencies of occurrence 
correspond to each other in a one-to-one relationship, and 
frequencies of occurrence and decoded data correspond to each 
other in a one-to-one relationship. Therefore, up to N items 
of decoded data are stored in the memory 303. 

When a frequency of occurrence is supplied to the address 
input terminal AD of the memory 303 as an address signal, 
decoded data associated with a Huffman code that occurs in that 
frequency is output from a data output terminal DO. 

In the i units of registers Rl through Ri, i Huffman codes 
which are in the first through i-th places in the frequency 
of occurrence are respectively stored. The comparators CI 
through Ci are provided in association with the respective 
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registers Rl through Ri. The comparators CI through Ci compare 
Huffman codes included in compressed image data supplied by 
the head search process portion 301 with Huffman codes stored 
in the respective registers Rl through Ri. When the Huffman 
codes supplied by the head search process portion 301 match 
the Huffman codes stored in the respective registers Rl through 
Ri, the comparators CI through Ci output a match signal, for 
example, at a high level and when not matched output a mismatch 
signal, for example, at a low level. 

The register 304 has i storage areas Ml through Mi in 
association with the registers Rl through Ri. In the storage 
areas Ml through Mi of the register 304 , decoded data associated 
with the Huffman codes in the first through i-th places in the 
frequency of occurrence are respectively stored. Each item 
of the decoded data is constituted by a run length and a group 
number . 

The selector 305 selectively outputs decoded data output 
by the memory 303 or decoded data output by the register 304. 

In the fifth embodiment, the registers Rl through Ri 
correspond to the first storage means; the comparators CI 
through Ci correspond to the match detection means; and the 
register 304 corresponds to the second storage means. The 
frequency- of -occurrence generating portion 302 corresponds to 
the frequency- of -occurrence generating means, the memory 303 
corresponds to the third storage means and the selector 305 
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corresponds to the selection means. 

Fig. 17 is a block diagram showing a configuration of 
the frequency- of -occurrence generating portion 302 of the 
Huffman decoder in Fig. 16. 

The frequency- of- occurrence generating portion 302 
includes a constant storing portion 321, a minimum code storing 
portion 322, a code length detecting portion 323, a selector 
324 and an adder 325. A Huffman code and a frequency of 
occurrence satisfy the following relational expression 

Frequency of occurrence = Huffman code - constant Mx 

A constant Mx is specific to the code length of a Huffman 
code and can be obtained through a calculation in advance. It 
is therefore possible to calculate the frequency of occurrence 
of an input Huffman code by detecting the code length thereof 
and using the constant Mx associated with the detected code 
length . 

Constants Mx associated with code lengths of 1 bit 
through 16 bits are stored in the constant storing portion 321 
in Fig. 17. For example, the constant storing portion 321 is 
constituted by a register. 

A minimum code for each of code lengths of Huffman codes 
is stored in the minimum code storing portion 322. 
Specifically, the minimum code storing portion 322 stores 16 
minimum codes in total from a minimum code for Huffman codes 
with a code length of 1 bit up to a minimum code for Huffman 
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codes with, a code length of 16 bits. For example, if there 
are three Huffman codes with a code length of 4 bits, i.e., 
"1010", "1011" and "1100" , "1010" is stored in the minimum code 
storing portion 322 as a minimum code for the Huffman codes 
with a code length of 4 bits . For example , the minimum code 
storing portion 322 is constituted by a register. 

The code length detecting portion 323 detects the code 
length of a Huffman code input thereto by comparing the input 
Huffman code with 16 Huffman codes output by the minimum code 
storing portion 322. 

The selector 324 selects one of 16 constants Mx output 
by the constant storing portion 321 based on the code length 
detected by the code length detecting portion 323 and supplies 
the selected constant Mx to one of input terminals of the adder 
325. The input Huffman code is supplied to the other input 
terminal of the adder 325. 

The adder 325 calculates a frequency of occurrence by 
subtracting the constant Mx from the input Huffman code and 
supplies the calculated frequency of occurrence to the address 
input terminal AD of the memory 303 as an address signal. As 
a result, decoded data constituted by a run length and a group 
number associated therewith is output from the data output 
terminal DO of the memory 303. 

In the fifth embodiment, the constant storing portion 
321 corresponds to the constant storing means ; the minimum code 
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storing portion 322 corresponds to the minimum code storing 
means; and the code length detecting portion 323 corresponds 
to the code length detection means. The selector 324 
corresponds to the constant selection means, and the adder 325 
corresponds to the calculation means . 

A method for Huffman decoding of the fifth embodiment 
will now be described. 

The method for Huffman decoding of the fifth embodiment 
includes the step of storing a predetermined number of Huffman 
codes among a plurality of Huffman codes respectively, the step 
of storing a predetermined number of decoded data associated 
with said predetermined number of Huffman codes respectively, 
detecting match between a Huffman code input thereto and said 
stored Huffman codes and outputting any of said predetermined 
number of decoded data in response to said match detection 
signal, the step of storing the decoded data in an address 
indicated by the frequency of occurrence of at least the 
plurality of remaining Huffman codes among said plurality of 
Huffman codes and generating a frequency of occurrence 
associated therewith based on the input Huffman code and the 
step of receiving said frequency of occurrence as an address 
signal and outputting decoded data from an address specified 
by the address signal. 

The method for decoding will now be described in detail . 

The head search process portion 301 detects the position 
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of the head of each Huffman code included in compressed image 
data, supplies 16 bits of compressed image data counted from 
the detected head position to the frequency -of -occurrence 
generating portion 302 and supplies 8 bits of compressed image 
data counted from the detected head position to the having the 
number of I comparators CI through Ci. 

The comparators CI through Ci compare Huffman codes 
included in the compressed image data supplied by the head 
search process portion 301 with Huffman codes stored in the 
respective registers Rl through Ri. When the Huffman codes 
supplied by the head search process portion 301 match any of 
the i Huffman codes stored in the registers Rl through Ri, any 
of the comparators CI through Ci outputs a match signal, for 
example, at a high level, and a mismatch signal, for example, 
at a low level is output by the other comparators - 

The signals output by the comparators CI through Ci are 
supplied to the register 304 as address signals. As a result, 
decoded data is output from a storage area among the storage 
areas Ml through Mi of the register 304 which is associated 
with the comparator that has output a match signal. 

In this case, the comparators CI through Ci and the 
registers Rl through Ri output decoded data in one cycle of 
a reference signal. 

When a Huffman code included in compressed image data 
supplied by the head search process portion 301 does not match 
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any of the Huffman codes stored in the registers Rl through 
Ri, a frequency of occurrence is output by the frequency- 
of -occurrence generating portion 302 based on the Huffman code 
included in the compressed image data. 

The frequency of occurrence output by the frequency- 
of -occurrence generating portion 302 is supplied to the address 
input terminal AD of the memory 303 as address signals. As 
a result, decoded data associated with a Huffman code having 
such a frequency of occurrence is output from the data output 
terminal DO of the memory 303. 

In this case, the frequency-of -occurrence generating 
portion 302 and the memory 303 output decoded data in three 
cycles of a reference signal. 

When the Huffman code supplied by the head search process 
portion 301 is a Huffman code having a frequency of occurrence 
which is equal to or higher than the i-th place, the selector 
305 outputs the decoded data output by the register 304 and, 
when the Huffman code supplied by the head search process 
portion 301 is not a Huffman code having a frequency of 
occurrence which is equal to or higher than the i-th place, 
the selector 305 outputs the decoded data output by the memory 
303. 

Since a Huffman code having a frequency of occurrence 
in any of the first through twentieth places occurs with a 
probability of about 90 % or more, about 90 % of Huffman codes 
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supplied by the head search process portion 301 are decoded 
in the process in one cycle at the comparators CI through Ci 
and register 304. Therefore^ the processing speed of the 
Huffman decoder as a whole is increased. 

Since there is one-to-one correspondence between 
Huffman codes and frequencies of occurrence and between 
frequencies of occurrence and decoded data, the maximum storage 
capacity required for the memory 303 is N words which is the 
same quantity as that of Huffman codes . Therefore, the Huffman 
decoder can be made compact . 

While Huffman codes with frequencies of occurrence in 
the first through twentieth places among a plurality of Huffman 
codes are stored in the registers Rl through Ri in the fifth 
embodiment, the number of Huffman codes stored in the registers 
Rl through Ri is not limited thereto, and any number of Huffman 
codes may be stored in the registers . 

While decoded data associated with all Huffman codes are 
stored in the memory 303 in the fifth embodiment, decoded data 
associated with Huffman codes excluding i Huffman codes stored 
in the registers Rl through Ri may be stored in the memory 303. 

All of the modes of carrying out the invention disclosed 
here should be regarded as examples and not limiting the 
invention in all aspects. 

Specifically, the encoding means is not limited to a 
Huffman encoding portion; the decoding means is not limited 
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to a Huffman decoding portion; the data storage means is not 
limited to a bank memory or register; the data storage means 
is not limited to an FIFO; and the data transfer means is not 
limited to a data bus . 
INDUSTRIAL APPLICABILITY 

As described above, an image data processor according 
to the invention makes it possible to rearrange data at a high 
speed and to achieve a reduced size and cost. Further, 
encoding and decoding can be performed with efficiency higher 
than in the prior art at a process of encoding image data or 
a process of decoding data with codes having a variable length 
which are image processing steps that must be especially 
performed at a high speed. The present invention also makes 
it possible to decode input data at a speed higher than that 
in the prior art without increasing the circuit scale of image 
processing means . 

Thus, the invention makes a great contribution to 
efforts toward decoding of codes at higher speeds without 
increasing the scale of a circuit and has a wide range of 
application in fields related to image processing. 
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CLAIMS 



1. A data processor for processing a block formed by 
two-dimensional data in a plurality of rows and a plurality 
of columns, characterized in that it comprises: 

storage means for storing the data of the block; 

write means for writing the data of the block in said 
storage means in a first order of scan; and 

read means for reading the data of the block stored in 
said storage means in a second order of scan and in that: 

said storage means includes n memories where n is an 
integer equal to or greater than 2, and the data of the block 
are distributed to said n memories such that n items of data 
consecutive in the first order of scan are stored in n different 
memories and n items of data consecutive in the second order 
of scan are stored in the different n memories; 

said write means simultaneously writes data in the 
different memories in the first order of scan; and 

said read means simultaneously reads the data from the 
different memories in the second order of scan. 

2. A data processor for processing a block formed by 
two-dimensional data in m rows and m columns, characterized 
in that it comprises: 

storage means for storing the data of the block; 
write means for writing the data of the block in said 
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storage means in a first order of scan; and 

read means for reading the data of the block stored in 
said storage means in a second order of scan and in that: 

said storage means includes n memories where said n is 
a divisor of m which is equal to or greater than 2, and the 
data of the block are distributed to said n memories such that 
n items of data consecutive in the first order of scan are stored 
in n different memories and n items of data consecutive in the 
second order of scan are stored in the different n memories; 

said write means simultaneously writes data in different 
n memories in the first order of scan; and 

said read means simultaneously reads the data from the 
n different memories in the second order of scan. 

3 . A data processor according to Claim 1 or 2 , 
characterized in that said first order of scan is the order 
of raster scan in either of a column direction and a row 
direction and in that said second order of scan is the order 
of raster scan in the other of the column direction and the 
row direction. 

4. A data processor according to Claim 1 or 2, 
characterized in that said first order of scan is either of 
the order of raster scan and the order of zigzag scan and in 
that said second order of scan is the other of the order of 
raster scan and the order of zigzag scan. 

5. A method for processing data for processing a block 
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formed by two-dimensional data in a plurality of rows and a 
plurality of columns, characterized in that it comprises the 
steps of: 

distributing the data of the block to n memories and 
storing them in the different memories by simultaneously 
writing the same in a first order of scan such that n items 
of data (n is an integer equal to or greater than 2) consecutive 
in the first order of scan are stored in the n different memories 
and such that n items of data consecutive in a second order 
of scan are stored in the n different memories; and 

reading the stored data of a block from the different 
memories in the second order of scan by. 

6. A method for processing data for processing a block 
formed by two-dimensional data in m rows and m columns, 
characterized in that it comprises the steps of: 

distributing the data of the block to n memories and 
storing them in the different memories by simultaneously 
writing the same in a first order of scan such that n items 
of data (n is an integer equal to or greater than 2, and n is 
a divisor of m which is equal to or greater than 2 ) consecutive 
in the first order of scan are stored in the n different memories 
and such that n items of data consecutive in a second order 
of scan are stored in the n different memories; and 

reading the stored data of a block from the different 
memories in the second order of scan by simulataneously . 
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7. A method for processing data according to Claim 5 or 
6 , characterized in that said first order of scan is the order 
of raster scan in either of the column direction and the row 
direction and in that said second order of scan is the order 
of raster scan in the other of the column direction and the 
row direction. 

8. A method for processing data according to Claim 5 or 
6, characterized in that said first order of scan is either 
of the order of raster scan and the order of zigzag scan and 
in that said second order of scan is the other of the order 
of raster scan and the order of zigzag scan. 

9. A Huffman encoder for encoding DCT coefficients into 
Huffman codes, characterized in that it comprises: 

storage means for storing a plurality of DCT 
coefficients ; 

read means for reading a plurality of the DCT 
coefficients stored in said storage means at a time; 

counting means for counting the number of consecutive 
invalid coefficients until a valid coefficient is encountered 
in the DCT coefficients read by said read means from said 
storage means and for sequentially outputting data constituted 
by combinations of the number of consecutive invalid 
coefficients and a valid coefficient; and 

encoding means for performing a Huffman encoding process 
based on the data sequentially output by said counting means 
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to generate Huffman codes. 

10. A Huffman encoder for encoding DCT coefficients into 
Huffman codes, characterized in that it comprises: 

storage means for storing a plurality of DCT 
coefficients ; 

read means for reading a plurality of the DCT 
coefficients stored in said storage means at a time; 

a plurality of data buses for respectively transferring 
a plurality of the DCT coefficients read by said read means 
from said storage means at a time; 

a plurality of data storage means for storing input data 
and outputting the same in the order of input; 

counting means for counting the number of consecutive 
invalid coefficients until a valid coefficient is encountered 
in the DCT coefficients transferred by said plurality of data 
buses and for sequentially inputting data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient to said plurality of data storage means ; 

selection means for sequentially selecting and 
outputting data respectively output by said plurality of data 
storage means ; and 

encoding means for performing a Huffman encoding process 
based on the data output by said selection means to generate 
Huffman codes. 

11. A Huffman decoder for decoding Huffman codes into 
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DCT coefficients, characterized in that it comprises: 

decoding means for performing a Huffman decoding process 
on Huffman codes input thereto to sequentially output data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; 

generation means for generating DCT coefficients based 
on the data output by said decoding means and for outputting 
a plurality of the generated DCT coefficients at a time; 

storage means for storing a plurality of DCT 
coefficients; and 

write means for writing a plurality of the DCT 
coefficients output by said generation means in said storage 
means at a time. 

12. A Huffman decoder for decoding Huffman codes into 
DCT coefficients, characterized in that it comprises: 

decoding means for performing a Huffman decoding process 
on Huffman codes input thereto to sequentially output data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; 

a plurality of data storage means for storing data input 
thereto and for outputting the same in the order. of input; 

selection means for selecting the data output by said 
decoding means and sequentially inputting the same to in order 
of said plurality of data storage means; 

generation means for generating DCT coefficients based 



73 



on the data output by said plurality of data storage means and 
for outputting a plurality of the generated DCT coefficients 
at a time; 

a plurality of data buses for respectively transferring 
a plurality of the DCT coefficients output by said generation 
means at a time; 

storage means for storing a plurality of DCT 
coefficients; and 

write means for writing a plurality of the DCT 
coefficients transferred by said plurality of data buses in 
said storage means at a time. 

13. A method for Huffman encoding for encoding DCT 
coefficients into Huffman codes, characterized in that it 
comprises the steps of: 

reading a plurality of DCT coefficients at a time; 

counting the number of consecutive invalid coefficients 
until a valid coefficient is encountered among the transferred 
DCT coefficients and sequentially calculating data 
constituted by combinations of the number of consecutive 
invalid coefficients and a valid coefficient; and 

performing a Huffman encoding process based on the 
sequentially calculated data to generate Huffman codes. 

14 . A method for Huffman encoding for encoding DCT 
coefficients into Huffman codes, characterized in that it 
comprises the steps of: 
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reading a plurality of DCT coefficients at a time; 

transferring the plurality of read DCT coefficients 
using a plurality of data buses respectively; 

storing the transferred data respectively; 

counting the number of consecutive invalid coefficients 
until a valid coefficient is encountered among the read DCT 
coefficients and sequentially calculating data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient; and 

performing a Huffman encoding process based on the 
calculated data to generate Huffman codes . 

15. A method for Huffman decoding for decoding Huffman 
codes into DCT coefficients, characterized in that it comprises 
the steps of: 

performing a Huffman decoding process on Huffman codes 
input thereto ; 

sequentially outputting data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient; 

generating DCT coefficients based on the output data; 

outputting a plurality of the generated DCT coefficients 
at a time; and 

writing a plurality of the output DCT coefficients at 
a time . 

16. A method for Huffman decoding for decoding Huffman 
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codes into DCT coefficients , characterized in that it comprises 
the steps of : 

performing a Huffman decoding process on Huffman codes 
input thereto; 

sequentially calculating data constituted by 
combinations of the number of consecutive invalid coefficients 
and a valid coefficient; 

selectively storing the calculated data; 

generating DCT coefficients based on the stored data; 

outputting a plurality of the generated DCT coefficients 
at a time; 

transferring the plurality of output DCT coefficients 
using a plurality of data buses respectively; and 

writing a plurality of the transferred DCT coefficients 
at a time. 

17. A Huffman decoder for decoding Huffman codes input 
thereto to output decoded data, characterized in that it 
comprises : 

a plurality of first storage means for respectively 
storing a predetermined number of Huffman codes among a 
plurality of Huffman codes; 

a plurality of match detection means provided in 
association with said plurality of first storage means for 
detecting match between an input Huffman code and the Huffman 
codes stored in the first storage means associated therewith; 
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second storage means for storing a predetermined number 
of decoded data associated with, said predetermined number of 
Huffman codes respectively and for outputtlng any of said 
predetermined number of decoded data in response to a signal 
output by said plurality of match detection means; 

frequency-of -occurrence generating means for 
generating a frequency of occurrence based on a Huffman code 
input thereto ; and 

third storage means for storing decoded data In an 
address indicated by the frequency of occurrence of at least 
the plurality of remaining Huffman codes among said plurality 
of Huffman codes , receiving the frequency of occurrence 
generated by said frequency-of -occurrence generating means as 
an address signal and outputtlng decoded data from an address 
specified by the address signal. 

18. The Huffman decoder according to Claim 17, 
characterized in that said predetermined number of Huffman 
codes have frequencies of occurrence higher than those of the 
remaining Huffman codes. 

19. The Huffman decoder according to Claim 17, 
characterized In that said frequency-of -occurrence generating 
means includes : 

constant storing means for storing a constant set for 
each code length of Huffman codes; 

minimum code storing means for storing a minimum code 
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for each code length of the Huffman codes; 

code length detection means for detecting the code 
length of a Huffman code input thereto based on the minimum 
code for each code length stored in said minimum code storing 
means ; 

constant selection means for selecting any of the 
constants stored in said constant storing means based on the 
code length detected by said code length detection means ; and 

calculation means for calculating a frequency of 
occurrence based on the constant selected by said constant 
selection means and the input Huffman code. 

20. A Huffman decoder according to Claim 17, 
characterized in that it further comprises decoded data 
selecting means for selectively outputting decoded data output 
by said second and third storage means. 

21. A method for Huffman decoding for decoding Huffman 
codes to output decoded data, characterized in that it 
comprises the steps of: 

storing a predetermined umber of Huffman codes among a 
plurality of Huffman codes respectively; 

storing a predetermined number of decoded data 
associated with said predetermined number of Huffman codes 
respectively; 

detecting match between an input Huffman code and said 
stored Huffman codes associated therewith; 
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outputting any of said predetermined number of decoded 
data in response to said match detection signal; 

storing decoded data in an address indicated by the 
frequency of occurrence of at least the plurality of remaining 
Huffman codes among said plurality of Huffman codes ; 

generating a frequency of occurrence based on the input 
Huffman code; 

receiving said frequency of occurrence as an address 
signal; and 

outputting decoded data from an address specified by 
said address signal. 

22 . A method for Huffman decoding according to Claim 21, 
characterized in that said predetermined number of Huffman 
codes have frequencies of occurrence higher than those of the 
remaining Huffman codes. 

23. A method for Huffman decoding according to Claim 21, 
characterized in that said step of generating a frequency of 
occurrence includes the steps of: 

storing a constant set for each code length of Huffman 

codes ; 

storing a minimum code for each code length of the 
Huffman codes ; 

detecting the code length of an input Huffman code based 
on said stored minimum code for each code length; 

selecting any of the stored constants based on said 
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detected code length; and 

generating a frequency of occurrence based on the 
selected constant and the input Huffman code. 

24 . A method for Huffman decoding according to Claim 21 . 
characterized in that the output decoded data are selectively 
output . 



ABSTRACT 



An apparatus for processing a block of image data at a 
high speed, in which two items of data consecutive in data scan 
are simultaneously written in different memories and are 
processed as a set of data having a valid portion and an invalid 
portion and in which the subsequent process is differentiated 
depending on the frequency of occurrence of the data to suppress 
any increase in the scale of the circuit and to increase the 
speed of the same. 
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Fig. 1 

A: write data 

B: high order bit 

C: low order bit 

D: read data 

3: control portion 

4 : bit switching portion 

5 : bit switching portion 

6 : write address counter 

7: read address counter 

8: address conversion portion 

9 : address conversion portion 

10: address conversion portion 

11: address conversion portion 

12: address switching portion 

13: address switching portion 

14: address switching portion 

15: address switching portion 

16: read data switching portion 

Fig. 4 

A: write data 
B: memory 1 write address 
data 

C: memory 2 
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Fig. 5 

A: read data 

B: memory 1 read address 
data 

C : memory 2 



Fig. 6 

A: 1st, 3rd, 5th, 7th rows: unchanged 

B: 2nt, 4th, 6th, 8th rows: shifted one place 



Fig. 7 

A: 1st, 5th rows: unchanged 

B: 2nt, 6th rows: shifted one place 

C: 3rd, 7th rows: shifted two places 

D: 4th, 8th rows: shifted three places 



Fig. 8 

A: 1st row: unchanged 

B: 2nt row: shifted one place 

C: 3rd row: shifted two places 

D: 4th row: shifted three places 

E: 5th row: shifted four places 

F: 6th row: shifted five places 

G: 7th row: shifted six places 
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H: 8th row: shifted seven places 

Fig. 10 

A: write data 
B: memory 1 write address 
data 

C: memory 2 write address 
data 

D: read data 

E: memory 1 read address 
data 

F: memory 2 read address 
data 

Fig. 11 

A: write data 
B: memory 1 write address 
data 

C: memory 2 write address 
data 

D: read data 

E: memory 1 read address 
data 

F: memory 2 read address 
Data 
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Fig. 13 

201: bank memory 
202: address generating portion 
203: data counter portion 
205: selector 

206: Huffman encoding portion 
Fig. 14 

A: four cycles 

B: contents of FIFO 204a 

C: run length 

D: valid coefficient 

E: contents of FIFO 204b 

F: five cycles 

Fig. 15 

211: Huffman decoding portion 

212: selector 

214: data counter portion 

215: bank memory 

216: address generating portion 

Fig. 16 

301: head search process portion 
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302 : frequency- of -occurrence generating portion 

303 : memory 

305: selector 

A: compressed image data 

B: Huffman code 

C: decoded data 

Rl : register 

CI : comparator 

Ri : register 

Ci : comparator 

Fig. 17 

302: frequency- of -occurrence generating portion 
303: memory 

321: constant storing portion 

322: minimum code storing portion 

323: code length detecting portion 

324: selector 

325: adder 

A: Huffman code 

B: frequency of occurrence 

C: decoded data 

D: code length 

Fig. 18 
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100: DCT process portion 

200: quantizing portion 

206 : Huffman encoding portion 

400: quantization table 

500: encoding table 

800: reverse DCT process portion 

700: dequantization portion 

211: Huffman decoding portion 

A: original image data 

B: compressed image data 

C: reproduced image data 

Fig. 19 

A: formation of blocks of image data 
B: block 

Fig. 20 

A: 8 X 8 pixel block 
B: DCT process 
C: frequency 

Fig. 21 

110: one-dimensional DCT circuit 

120: inversion memory 

130: one -dimensional DCT circuit 
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Fig. 22 

A: frequency In horizontal direction 
B: frequency in vertical direction 
C: low 
D high 

Fig, 23 

A: zigzag scan 

B: DCT coefficient 

Fig. 24 

A: raster scan (direction of rows) 
B: raster scan (direction of columns) 

Fig. 25 

A: raster scan (direction of rows) 
B: zigzag (direction of columns) 

Fig. 26 

221: bank memory 

222: Huffman encoding circuit 

Fig. 27 
Eight cycles 
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Fig. 28 

311: head search process portion 
312: memory 

{2^ words) 
A: compressed image data 
C: decoded data 
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FIG. 2(b) 
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FIG. 2(c) 
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FIG. 9(d) 
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FIG. 12(b) 
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I Docket No. 3620-4010 

^^MBDip^ECLARATION AND POWER OF ATTORNEY FOR 
OMiabS^^ESIGN, NATIONAL STAGE OF PCT, SUPPLEMENTAL 
DIVISIONAL. CONTINUATION OR CONTINUATION-IN-PART APPLICATION 

As a below name inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name, 

I believe I am an original, first and joint inventor of the subject matter which is claimed and for which a patent is 
sought on the invention entitled: 

ESIAGE DATA PROCESS OR AND PROCESSING METHOD 

the specification of which 

a. [ ] is attached hereto 

b. [X] was filed on 8/16/00 as application Serial No. 09/622.424 and was amended on 

. (if applicable). 

PCT FILED APPLICATION ENTERE^G NATIONAL STAGE 

c. [X] was described and claimed in Intemational Application No. PCT/JP99/00860 filed on 

February 24. 1999 and as amended on . (if any). 

I hereby state that I have reviewed and understand the contents of the above-identified specification, including 
the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the patentabihty as defined in Title 37, Code 
of Federal Regulations, § 1.56. 

I hereby specify the following as the correspondence address to which all communications about this application 
are to be directed: 



SEND CORRESPONDENCE TO: 



DIRECT TELEPHONE CALLS TO: 



MORGAN & FINNEGAN. L.L.P^ 
345 Park Avenue 

Michael M. Murray, Esq. 
(212)758-4800 



[X] I hereby claim foreign priority benefits under Title 35, United States Code § 1 19(a)-(d) or under 
§ 365(b) of any foreign application(s) for patent or inventor's certificate or under § 365(a) of any PCT 
intemational application(s) designating at least one country other than the U.S. listed below and also have 
identified below such foreign application(s) for patent or inventor's certificate or such PCT intemational 
application(s) filed by me on the same subject matter having a filing date within twelve (12) months before that 
of the application on which priority is claimed: 

[X] The attached 35 U.S.C. § 1 19 claim for priority for the application(s) listed below forms a part of 
this declaration. 
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Countrv/PCT 


Application 
Number , 


Date of filing 
(dav, month, vr"* 


Date of Issue 
("day. month, vr) 


Priority 
Claimed 

[X] YES [ ]NO 


Japan 


10/46478 


27-reb-98 




Japan 


10/54017 


5-March-98 




[X] YES [ ] NO 


Japan 


10/112465 


22-April-98 




X] YES [ ] NO 



[ ] I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any U.S. provisional application(s) listed below. 
Provisional Application No. Date of Filing (day, month, yr) 



ADDITIONAL STATEMENTS FOR DIVISIONAL, CONTINUATION OR CONTINUATION-IN-PART 
OR PCT INTERNATIONAL APPLICATION(S) rOESIGNATING THE U.S.) 

I hereby claim the benefit under Title 35, United States Code § 120 of any United States application(s) or under 
§ 365(c) of any PCT international application(s) designating the U.S. listed below. 



US/PCT Application Serial No. 



Filing Date 



Status (patented, pending, abandoned)/ 
U.S. application no. assigned (For PCT) 



US/PCT Application Serial No. 



Status (patented, pending, abandoned)/ 
U.S. application no. assigned (For PCT) 



[ ] In this continuation-in-part application, insofar as the subject matter of any of the claims of this 
application is not disclosed in the above listed prior United States or PCT international application(s) in the 
manner provided by the furst paragraph of Title 35, United States Code, § 1 12, 1 acknowledge the duty to 
disclose material information as defined m Title 37, Code of Federal Regulations, § 1 .56(a) which occurred 
between the filing date of Ihe prior application(s) and the national or PCT international filing date of this 
application. 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge 
that willful false statements and the like so made are punishable by fine or Imprisonment, or both, under Section 
1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of 
the application or any patent issued thereon. * 

I hereby appoint the following attomeys and/or agents with full power of substitution and revocation, to 
prosecute this application, to receive the patent, and to transact all business in the Patent and Trademark Office 
connected therewith: John A. Diaz (Reg. No. 19,550), John C. Vassil (Reg. No. 19,098), Alfred P. Ewert (Reg. 
No. IgJ^X), David H. Pfeffer (Reg. No. IRMSX. Harry C. Marcus (Reg. No^390,), Robert E. Paulson (Reg. 
No. 21gO-4&>, Stephen R. Smith (Reg. No. J^,dli). Kurt E. Richter (Reg. NcuJdjQSZ), J. Robert Dailey (Reg. 
No. :?7^r34}^ugene Moroz (Reg. No. 25j237}John F. Sweeney (Reg. No. 27,471), Arnold I. Rady (keg. No. 
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.26,601), Christopher A. Hughes (Reg. No. 26,914}, William S. Feiler (Reg. No. jZejTS), Joseph A. Calvaruso 
(RigTNo. 28,287), James W. Gould (Reg. No.^859)^Richard C. Komson (Reg. No. 21,913)^, Israel Blum 
(Reg. No. Bartholomew Verdirame (Reg. No. 2SJMX Maria C.H. Lin (reg. No. ISJIT), Joseph A. 

DeGirolamo (Reg^No. 28^}, Michael P. Dougherty (Reg. No. 32J30), Seth J. Atlas (Reg. No. 32,454), 
Andrew M. Riddles (Reg. No. 31^657), Bruce D. DeRenzi (Reg. No..33>676X Michael M. Murray (KegTNo. 
32^537), Mark J. Abate (Reg. No .,32,527), Harold Haidt (Reg. No. 17^09), John T. Gallagher (Reg. No. 
35,516), Steven F. Meyer (Reg. No.J5,613) and Kenneth H, Sonnenfeld (Reg. No. 33^85); Michael S. Marcus 
O^g. No. 3J[^727Xand John E. Hoel (Reg. No.,26j2792of Morgan & Finnegan, L.L.P. ^ose address is: 345 
Park Avenue, New York, New York, 10154, . 

[ ] I hereby authorize the U.S. attorneys and/or agents named hereinabove to accept and follow 
instructions from 



as to any action to be taken in the U.S. Patent and Trademark Office 

regarding this application without direct communication between the U.S. attorneys and/or agents and 
me. In the event of a change in the person(s) from whom instructions may be taken I will so notify the 
U.S. attorneys and/or agents hereinabove. 



Full name of first joint inventor Kgnji HIRANO 

Inventor's signature* Kenii HI^AKiO October- 25 .2 c?oo 

d date ^ T/^ 
Residence 1-23, Ebisunochohigashi 4-chome, Sakai^ghi^saka 590-0945, Japan -J fyC 

Citizenship Japan 

Post Office Address 1-23, Ebisunochohigashi 4-chome, Sakai-shi, Osaka 590-0945, Japan 



Full name of second j oint inventor Shinji^TAMURA_. 



Inventor's signature* S'ArnJi /{ITAMURA OcToLpk-^j 2f^OO 

Residence 3-11-104, Higashikoutari 1-chome, Nagaokako-shi, Kyoto 617-0832, Japan ^ xD,y^ 

Citizenship Japan 

Post Office Address 3- 1 1 - 1 04, Higashikoutari 1 -chome, Nagaokako-shi, Kyoto 6 1 7-0832, Japan 



Full name of third joint inventor Tatsuhiko 



Inventor's signature* TaI^C^ Hi'Ico H t^l^H^ ^DV&.'Vsb^ < ^ f j^aot? 
Residence 7-2-304, Katsurahitsujisarucho, Nghikyo-ku, Kyoto 615-8084, Japan 'j 



Citizenship Japan 



Post Office Address 7-2-304, Katsurahitsujisarucho, Nishikyo-ku, Kyoto 615-8084, Japan 
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[ ] ATTACHED IS/ARE ADDED PAGE(S) TO COMBINED DECLARATION AND POWER OF 
ATTORNEY FORM FOR SIGNATURE BY FOURTH AND SUBSEQUENT INVENTORS 

* Before signing this declaration, each person signing must: 

1 . Review the declaration and verify the correctness of all information therein; and 

2. Review the specification and the claims, including any amendments made to the claims. 

After the declaration is signed, the specification and claims are not to be altered. 
To the inventor(s): 

The following are cited in or pertinent to the declaration attached to the accompanying application: 

Title 37. Code of Federal Regulation. § 1.56 

Duty to disclose information material to patentability. 

(a) A patent by its very nature is affect with a public interest. The public interest is best served, 
and the most effective patent examination occurs when, at the time an application is being examined, 
the Office is aware of and evaluates the teachings of all information material to patentability. Each 
individual associated with the filing and prosecution of a patent application has a duty of candor and 
good faith in dealing with the Office, which includes a duty to disclose to the Office all information 
known to that individual to be material to patentability as defined in this section. The duty to disclose 
information exists with respect to each pending claim until the claim is canceled or withdrawn fiom 
consideration, or the application becomes abandoned. Information material to the patentability of a 
claim that is canceled or withdrawn from consideration need not be submitted if the information is not 
material to the patentability of any claim remaining vmder consideration in the application. There is no 
duty to submit information which is not material to the patentability of any existing claim. The duty to 
disclose all information known to be material to patentability is deemed to be satisfied if all 
information known to be material to patentability of any claim issued in patent was cited by the Office 
or submitted to the Office in the manner prescribed by §§ 1 .97(b)-(d) and 1.98. However, no patent will 
be granted on an application in connection with which fraud on the Office was practiced or attempted 
or the duty of disclosure was violated through bad faith or intentional misconduct. The Office 
encourages applicants to carefiiUy examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) the closest information over which individuals associated with the filing or 
prosecution of a patent application believe any pending claim patentably defines, to 
make sure that any material information contained therein is disclosed to the Office. 

Title 35. U.S. Code $ 101 
Inventions patentable 

Whoever invents or discovers any new and useful process, machine, manufacture, or composition of 
matter, or any new and useful improvement thereof, may obtain a patent therefor, subject to the conditions and 
requirements of this tide. 
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Title 35 U.S. Code S 102 

Conditions for patentability; novelty and loss of right to patent 
A person shall be entitled to a patent unless - 

(a) the invention was known or used by others in this country, or patented or described in a 
printed publication ia this or a foreign country, before the invention thereof by the applicant for patent, 

(b) the invention was patented or described in a printed publication in this or foreign country or in 
public use or on sale in this country, more than one year prior to the date of application for patent in the United 
States, or 

(c) he has abandoned the invention, or 

(d) the invention was first patented or caused to be patented, or was the subject of an inventor's 
certificate, by the applicant or his legal representatives or assigns in a foreign country prior to the date of the 
application for patent in this country on an application for patent or inventor's certificate field more than twelve 
months before the filing of the application in the United States, or 

(e) the invention was described in a patent granted on an application for patent by another filed in 
the United States before the invention thereof by the applicant for patent, or on an international application by 
another who has fulfilled the requirements of paragraphs (1), (2), and (4) of section 371(c) of this title before 
the invention thereof by the applicant for patent, or 

(f) he did not himself invent the subject matter sought to be patented, or 

(g) before the applicant's invention thereof the invention was made in this country by another had 
not abandoned, suppressed, or concealed it. In determining priority of invention there shall be considered not 
only the respective dates of conception and reduction to practice of the invention, but also the reasonable 
diligence of one who was first to conceive and last to reduce to practice, ftom a time prior to conception by the 
other . . . 

Title 35. U.S. Code § 103 

Conditions for patentability; non-obvious subject matter 

A patent may not be obtained though the invention is not identically disclosed or described as set forth 
in section 102 of this title, if the differences between the subject matter sought to be patented and the prior art 
are such that the subject matter as a whole would have been obvious at the time the invention was made to a 
person having ordinary skill in the art to which said matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

Subject matter developed by another person, which quahfies as prior art only imder subsection (f) or 
(g) of section 102 of this title, shall not preclude patentability under this section where the subject matter and the 
claimed invention were, at the time the invention was made, owned by the same person or subject to an 
obhgation of assignment to the same person. 

Title 35, U.S. Code § 1 12 (in part) 
Specification 

The specification shall contain a written description of the invention, and of the manner and process of 
making and using it, in such fiill, clear, concise and exact terms also enable any person skilled in the art to 



-5- 

5705 14_1 



Docket No. 3620-4010 



which it pertains, or with which it is mostly nearly connected, to make and use the same, and shall set forth the 
best mode contemplated by the inventor of carrying out his invention. 

Title 35. U.S. Codes 119 

Benefit of earlier filing date in foreign country; right of priority 

An apphcation for patent for an invention filed in this country by any person who has, or whose legal 
representatives or assigns have, previously regularly filed an apphcation for a patent for the same invention ia a 
foreign coimtry which affords similar privileges in the case of applications filed in the United States or to 
citizens of the United States, shall have the same effect as the same application would have if filed in this 
country on the date on which the application for patent for the same invention was first filed in such foreign 
country, if the application in this country is filed within twelve months from the earliest date on which such 
foreign application was filed; but no patent shall be granted on any apphcation for patent for an invention which 
had been patented or described in a printed publication in any country more than one year before the date of he 
actual filing of the application in this country, or which had been in public use or on sale in this country more 
than one year prior to such filing. 

Title 35. U.S. Codes 120 

Benefit or earher filmg date in the United States 

An application for patent for an invention disclosed in the manner provided by the first paragraph of 
section 1 12 of this title in an application previously filed in the United States, or as provided by section 363 of 
this title, which is filed by an inventor or inventors named in the previously filed application shall have the same 
effect, as to such invention, as though filed on the date of the prior application, if filed before the patenting or 
abandonment of or termination of proceedings on the first application or an application similarly entitled to the 
benefit of the filing date of the first application and if it contains or is amended to contain a specific reference to 
the earlier filed application. 

Please read carefally before signing the Declaration attached to the accompanying Apphcation. 
If you have any questions, please contact Morgan & Finnegan, L.L.P. 
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